@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.
Files changed (178) hide show
  1. package/client.d.ts +1 -0
  2. package/client.js +79 -36
  3. package/client.js.map +1 -0
  4. package/compression.d.ts +1 -1
  5. package/compression.js +13 -49
  6. package/compression.js.map +1 -0
  7. package/cursors.d.ts +3 -2
  8. package/cursors.js +10 -14
  9. package/cursors.js.map +1 -0
  10. package/index.d.ts +19 -4
  11. package/index.js +187 -13
  12. package/index.js.map +1 -0
  13. package/indexConfiguration/base.d.ts +6 -0
  14. package/indexConfiguration/base.js +42 -0
  15. package/indexConfiguration/base.js.map +1 -0
  16. package/indexConfiguration/common.d.ts +9 -0
  17. package/indexConfiguration/common.js +54 -0
  18. package/indexConfiguration/common.js.map +1 -0
  19. package/indexConfiguration/index.d.ts +3 -0
  20. package/indexConfiguration/index.js +40 -0
  21. package/indexConfiguration/index.js.map +1 -0
  22. package/indexConfiguration/japanese.d.ts +6 -0
  23. package/indexConfiguration/japanese.js +121 -0
  24. package/indexConfiguration/japanese.js.map +1 -0
  25. package/indexPrefix.d.ts +1 -0
  26. package/indexPrefix.js +12 -0
  27. package/indexPrefix.js.map +1 -0
  28. package/indices.d.ts +9 -0
  29. package/indices.js +30 -0
  30. package/indices.js.map +1 -0
  31. package/limit.js +2 -8
  32. package/limit.js.map +1 -0
  33. package/normalize.d.ts +1 -0
  34. package/normalize.js +47 -12
  35. package/normalize.js.map +1 -0
  36. package/operations/ElasticsearchCatHealth.d.ts +7 -0
  37. package/operations/ElasticsearchCatHealth.js +38 -0
  38. package/operations/ElasticsearchCatHealth.js.map +1 -0
  39. package/operations/ElasticsearchCatNodes.d.ts +7 -0
  40. package/operations/ElasticsearchCatNodes.js +36 -0
  41. package/operations/ElasticsearchCatNodes.js.map +1 -0
  42. package/operations/index.d.ts +3 -0
  43. package/operations/index.js +40 -0
  44. package/operations/index.js.map +1 -0
  45. package/operations/stripConnectionFromException.d.ts +1 -0
  46. package/operations/stripConnectionFromException.js +24 -0
  47. package/operations/stripConnectionFromException.js.map +1 -0
  48. package/operations/types.d.ts +35 -0
  49. package/operations/types.js +14 -0
  50. package/operations/types.js.map +1 -0
  51. package/operators.d.ts +5 -14
  52. package/operators.js +37 -32
  53. package/operators.js.map +1 -0
  54. package/package.json +12 -25
  55. package/plugins/definition/ElasticsearchBodyModifierPlugin.d.ts +1 -1
  56. package/plugins/definition/ElasticsearchBodyModifierPlugin.js +3 -12
  57. package/plugins/definition/ElasticsearchBodyModifierPlugin.js.map +1 -0
  58. package/plugins/definition/ElasticsearchFieldPlugin.d.ts +11 -17
  59. package/plugins/definition/ElasticsearchFieldPlugin.js +22 -75
  60. package/plugins/definition/ElasticsearchFieldPlugin.js.map +1 -0
  61. package/plugins/definition/ElasticsearchIndexPlugin.d.ts +18 -0
  62. package/plugins/definition/ElasticsearchIndexPlugin.js +36 -0
  63. package/plugins/definition/ElasticsearchIndexPlugin.js.map +1 -0
  64. package/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin.d.ts +6 -2
  65. package/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin.js +12 -8
  66. package/plugins/definition/ElasticsearchQueryBuilderOperatorPlugin.js.map +1 -0
  67. package/plugins/definition/ElasticsearchQueryModifierPlugin.d.ts +1 -1
  68. package/plugins/definition/ElasticsearchQueryModifierPlugin.js +3 -12
  69. package/plugins/definition/ElasticsearchQueryModifierPlugin.js.map +1 -0
  70. package/plugins/definition/ElasticsearchSortModifierPlugin.d.ts +1 -1
  71. package/plugins/definition/ElasticsearchSortModifierPlugin.js +3 -12
  72. package/plugins/definition/ElasticsearchSortModifierPlugin.js.map +1 -0
  73. package/plugins/definition/index.d.ts +6 -0
  74. package/plugins/definition/index.js +73 -0
  75. package/plugins/definition/index.js.map +1 -0
  76. package/plugins/index.d.ts +2 -0
  77. package/plugins/index.js +29 -0
  78. package/plugins/index.js.map +1 -0
  79. package/plugins/operator/andIn.d.ts +1 -1
  80. package/plugins/operator/andIn.js +6 -20
  81. package/plugins/operator/andIn.js.map +1 -0
  82. package/plugins/operator/between.d.ts +1 -1
  83. package/plugins/operator/between.js +10 -22
  84. package/plugins/operator/between.js.map +1 -0
  85. package/plugins/operator/contains.d.ts +1 -1
  86. package/plugins/operator/contains.js +4 -16
  87. package/plugins/operator/contains.js.map +1 -0
  88. package/plugins/operator/equal.d.ts +1 -1
  89. package/plugins/operator/equal.js +31 -19
  90. package/plugins/operator/equal.js.map +1 -0
  91. package/plugins/operator/gt.d.ts +1 -1
  92. package/plugins/operator/gt.js +4 -15
  93. package/plugins/operator/gt.js.map +1 -0
  94. package/plugins/operator/gte.d.ts +1 -1
  95. package/plugins/operator/gte.js +4 -15
  96. package/plugins/operator/gte.js.map +1 -0
  97. package/plugins/operator/in.d.ts +1 -1
  98. package/plugins/operator/in.js +9 -27
  99. package/plugins/operator/in.js.map +1 -0
  100. package/plugins/operator/index.d.ts +3 -0
  101. package/plugins/operator/index.js +36 -27
  102. package/plugins/operator/index.js.map +1 -0
  103. package/plugins/operator/japanese/contains.d.ts +8 -0
  104. package/plugins/operator/japanese/contains.js +44 -0
  105. package/plugins/operator/japanese/contains.js.map +1 -0
  106. package/plugins/operator/lt.d.ts +1 -1
  107. package/plugins/operator/lt.js +4 -15
  108. package/plugins/operator/lt.js.map +1 -0
  109. package/plugins/operator/lte.d.ts +1 -1
  110. package/plugins/operator/lte.js +4 -15
  111. package/plugins/operator/lte.js.map +1 -0
  112. package/plugins/operator/not.d.ts +1 -1
  113. package/plugins/operator/not.js +27 -16
  114. package/plugins/operator/not.js.map +1 -0
  115. package/plugins/operator/notBetween.d.ts +1 -1
  116. package/plugins/operator/notBetween.js +9 -21
  117. package/plugins/operator/notBetween.js.map +1 -0
  118. package/plugins/operator/notContains.d.ts +1 -1
  119. package/plugins/operator/notContains.js +4 -16
  120. package/plugins/operator/notContains.js.map +1 -0
  121. package/plugins/operator/notIn.d.ts +1 -1
  122. package/plugins/operator/notIn.js +6 -18
  123. package/plugins/operator/notIn.js.map +1 -0
  124. package/plugins/operator/notStartsWith.d.ts +7 -0
  125. package/plugins/operator/notStartsWith.js +30 -0
  126. package/plugins/operator/notStartsWith.js.map +1 -0
  127. package/plugins/operator/startsWith.d.ts +7 -0
  128. package/plugins/operator/startsWith.js +30 -0
  129. package/plugins/operator/startsWith.js.map +1 -0
  130. package/sharedIndex.d.ts +1 -0
  131. package/sharedIndex.js +12 -0
  132. package/sharedIndex.js.map +1 -0
  133. package/sort.d.ts +5 -4
  134. package/sort.js +22 -17
  135. package/sort.js.map +1 -0
  136. package/types.d.ts +178 -6
  137. package/types.js +14 -3
  138. package/types.js.map +1 -0
  139. package/utils/createIndex.d.ts +20 -0
  140. package/utils/createIndex.js +100 -0
  141. package/utils/createIndex.js.map +1 -0
  142. package/utils/index.d.ts +3 -0
  143. package/utils/index.js +29 -0
  144. package/utils/index.js.map +1 -0
  145. package/utils/waitUntilHealthy/UnhealthyClusterError.d.ts +4 -0
  146. package/utils/waitUntilHealthy/UnhealthyClusterError.js +18 -0
  147. package/utils/waitUntilHealthy/UnhealthyClusterError.js.map +1 -0
  148. package/utils/waitUntilHealthy/WaitUntilHealthy.d.ts +71 -0
  149. package/utils/waitUntilHealthy/WaitUntilHealthy.js +157 -0
  150. package/utils/waitUntilHealthy/WaitUntilHealthy.js.map +1 -0
  151. package/utils/waitUntilHealthy/WaitingHealthyClusterAbortedError.d.ts +4 -0
  152. package/utils/waitUntilHealthy/WaitingHealthyClusterAbortedError.js +18 -0
  153. package/utils/waitUntilHealthy/WaitingHealthyClusterAbortedError.js.map +1 -0
  154. package/utils/waitUntilHealthy/index.d.ts +6 -0
  155. package/utils/waitUntilHealthy/index.js +51 -0
  156. package/utils/waitUntilHealthy/index.js.map +1 -0
  157. package/utils/waitUntilHealthy/reason/ClusterHealthReason.d.ts +15 -0
  158. package/utils/waitUntilHealthy/reason/ClusterHealthReason.js +21 -0
  159. package/utils/waitUntilHealthy/reason/ClusterHealthReason.js.map +1 -0
  160. package/utils/waitUntilHealthy/reason/IReason.d.ts +4 -0
  161. package/utils/waitUntilHealthy/reason/IReason.js +7 -0
  162. package/utils/waitUntilHealthy/reason/IReason.js.map +1 -0
  163. package/utils/waitUntilHealthy/reason/MemoryReason.d.ts +14 -0
  164. package/utils/waitUntilHealthy/reason/MemoryReason.js +21 -0
  165. package/utils/waitUntilHealthy/reason/MemoryReason.js.map +1 -0
  166. package/utils/waitUntilHealthy/reason/ProcessorReason.d.ts +14 -0
  167. package/utils/waitUntilHealthy/reason/ProcessorReason.js +21 -0
  168. package/utils/waitUntilHealthy/reason/ProcessorReason.js.map +1 -0
  169. package/utils/waitUntilHealthy/reason/index.d.ts +3 -0
  170. package/utils/waitUntilHealthy/reason/index.js +40 -0
  171. package/utils/waitUntilHealthy/reason/index.js.map +1 -0
  172. package/where.d.ts +5 -5
  173. package/where.js +11 -26
  174. package/where.js.map +1 -0
  175. package/plugins/GzipCompression.d.ts +0 -19
  176. package/plugins/GzipCompression.js +0 -75
  177. package/plugins/definition/CompressionPlugin.d.ts +0 -20
  178. 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/between";
2
- import { ElasticsearchQueryBuilderOperatorNotBetweenPlugin } from "./plugins/operator/notBetween";
3
- import { ElasticsearchQueryBuilderOperatorContainsPlugin } from "./plugins/operator/contains";
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 | ElasticsearchQueryBuilderOperatorNotBetweenPlugin | ElasticsearchQueryBuilderOperatorContainsPlugin | ElasticsearchQueryBuilderOperatorNotContainsPlugin | ElasticsearchQueryBuilderOperatorEqualPlugin | ElasticsearchQueryBuilderOperatorNotPlugin | ElasticsearchQueryBuilderOperatorGreaterThanPlugin | ElasticsearchQueryBuilderOperatorGreaterThanOrEqualToPlugin | ElasticsearchQueryBuilderOperatorLesserThanPlugin | ElasticsearchQueryBuilderOperatorLesserThanOrEqualToPlugin | ElasticsearchQueryBuilderOperatorInPlugin | ElasticsearchQueryBuilderOperatorAndInPlugin | ElasticsearchQueryBuilderOperatorNotInPlugin)[];
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 _between = require("./plugins/operator/between");
9
-
10
- var _notBetween = require("./plugins/operator/notBetween");
11
-
12
- var _contains = require("./plugins/operator/contains");
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
- exports.getElasticsearchOperators = getElasticsearchOperators;
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
@@ -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-mt-2",
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/error": "0.0.0-mt-2",
17
- "@webiny/handler": "0.0.0-mt-2",
18
- "@webiny/plugins": "0.0.0-mt-2",
19
- "@webiny/utils": "0.0.0-mt-2",
20
- "aws-elasticsearch-connector": "9.0.3",
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
- "@babel/cli": "^7.5.5",
26
- "@babel/core": "^7.5.5",
27
- "@webiny/cli": "^0.0.0-mt-2",
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": "yarn webiny run build",
39
- "watch": "yarn webiny run watch"
32
+ "build": "node ../cli/bin.js run build",
33
+ "watch": "node ../cli/bin.js run watch"
40
34
  },
41
- "adio": {
42
- "ignore": {
43
- "src": [
44
- "aws-sdk"
45
- ]
46
- }
47
- },
48
- "gitHead": "3c0dcfb3c22c9f83107fdb97b25014cd03d9db7d"
35
+ "gitHead": "06b2ede40fc2212a70eeafd74afd50b56fb0ce82"
49
36
  }
@@ -1,5 +1,5 @@
1
1
  import { Plugin } from "@webiny/plugins";
2
- import { SearchBody } from "elastic-ts";
2
+ import type { SearchBody } from "elastic-ts";
3
3
  export interface ModifyBodyParams {
4
4
  body: SearchBody;
5
5
  }
@@ -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
- exports.ElasticsearchBodyModifierPlugin = ElasticsearchBodyModifierPlugin;
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 declare type UnmappedTypes = "date" | "long" | string;
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 Params {
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 abstract class ElasticsearchFieldPlugin extends Plugin {
51
+ export declare class ElasticsearchFieldPlugin extends Plugin {
52
52
  static readonly type: string;
53
53
  static readonly ALL: string;
54
- private readonly _field;
55
- private readonly _path;
56
- private readonly _keyword;
57
- private readonly _unmappedType;
58
- private readonly _sortable;
59
- private readonly _searchable;
60
- get field(): string;
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 (keywordLessUnmappedType.includes(type)) {
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
- get field() {
30
- return this._field;
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
- (0, _defineProperty2.default)(this, "_field", void 0);
56
- (0, _defineProperty2.default)(this, "_path", void 0);
57
- (0, _defineProperty2.default)(this, "_keyword", void 0);
58
- (0, _defineProperty2.default)(this, "_unmappedType", void 0);
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._keyword = false;
27
+ this.keyword = false;
68
28
  }
69
-
70
- this._sortable = params.sortable === undefined ? true : params.sortable;
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
- return _objectSpread(_objectSpread({}, options), {}, {
88
- unmapped_type: this._unmappedType
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._keyword ? ".keyword" : ""}`;
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._path === this.constructor.ALL) {
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
- (0, _defineProperty2.default)(ElasticsearchFieldPlugin, "type", "elasticsearch.fieldDefinition");
128
- (0, _defineProperty2.default)(ElasticsearchFieldPlugin, "ALL", "*");
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 = "elasticsearch.queryBuilder.operator";
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
  }