@powersync/service-sync-rules 0.29.10 → 0.31.0
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/dist/BaseSqlDataQuery.d.ts +3 -9
- package/dist/BaseSqlDataQuery.js +11 -21
- package/dist/BaseSqlDataQuery.js.map +1 -1
- package/dist/BucketParameterQuerier.d.ts +42 -9
- package/dist/BucketParameterQuerier.js +30 -7
- package/dist/BucketParameterQuerier.js.map +1 -1
- package/dist/BucketSource.d.ts +94 -25
- package/dist/BucketSource.js +67 -0
- package/dist/BucketSource.js.map +1 -1
- package/dist/ExpressionType.d.ts +4 -2
- package/dist/ExpressionType.js.map +1 -1
- package/dist/HydratedSyncRules.d.ts +46 -0
- package/dist/HydratedSyncRules.js +88 -0
- package/dist/HydratedSyncRules.js.map +1 -0
- package/dist/HydrationState.d.ts +45 -0
- package/dist/HydrationState.js +41 -0
- package/dist/HydrationState.js.map +1 -0
- package/dist/SqlBucketDescriptor.d.ts +31 -28
- package/dist/SqlBucketDescriptor.js +89 -112
- package/dist/SqlBucketDescriptor.js.map +1 -1
- package/dist/SqlDataQuery.d.ts +4 -4
- package/dist/SqlDataQuery.js +5 -6
- package/dist/SqlDataQuery.js.map +1 -1
- package/dist/SqlParameterQuery.d.ts +17 -9
- package/dist/SqlParameterQuery.js +49 -23
- package/dist/SqlParameterQuery.js.map +1 -1
- package/dist/SqlSyncRules.d.ts +11 -53
- package/dist/SqlSyncRules.js +11 -376
- package/dist/SqlSyncRules.js.map +1 -1
- package/dist/StaticSqlParameterQuery.d.ts +13 -3
- package/dist/StaticSqlParameterQuery.js +38 -4
- package/dist/StaticSqlParameterQuery.js.map +1 -1
- package/dist/SyncConfig.d.ts +43 -0
- package/dist/SyncConfig.js +102 -0
- package/dist/SyncConfig.js.map +1 -0
- package/dist/TablePattern.d.ts +22 -4
- package/dist/TablePattern.js +57 -19
- package/dist/TablePattern.js.map +1 -1
- package/dist/TableValuedFunctionSqlParameterQuery.d.ts +14 -4
- package/dist/TableValuedFunctionSqlParameterQuery.js +41 -7
- package/dist/TableValuedFunctionSqlParameterQuery.js.map +1 -1
- package/dist/compatibility.d.ts +7 -0
- package/dist/compatibility.js +34 -0
- package/dist/compatibility.js.map +1 -1
- package/dist/compiler/bucket_resolver.d.ts +70 -0
- package/dist/compiler/bucket_resolver.js +131 -0
- package/dist/compiler/bucket_resolver.js.map +1 -0
- package/dist/compiler/compatibility.d.ts +16 -0
- package/dist/compiler/compatibility.js +12 -0
- package/dist/compiler/compatibility.js.map +1 -0
- package/dist/compiler/compiler.d.ts +110 -0
- package/dist/compiler/compiler.js +130 -0
- package/dist/compiler/compiler.js.map +1 -0
- package/dist/compiler/equality.d.ts +99 -0
- package/dist/compiler/equality.js +284 -0
- package/dist/compiler/equality.js.map +1 -0
- package/dist/compiler/expression.d.ts +77 -0
- package/dist/compiler/expression.js +122 -0
- package/dist/compiler/expression.js.map +1 -0
- package/dist/compiler/filter.d.ts +71 -0
- package/dist/compiler/filter.js +110 -0
- package/dist/compiler/filter.js.map +1 -0
- package/dist/compiler/filter_simplifier.d.ts +26 -0
- package/dist/compiler/filter_simplifier.js +119 -0
- package/dist/compiler/filter_simplifier.js.map +1 -0
- package/dist/compiler/ir_to_sync_plan.d.ts +37 -0
- package/dist/compiler/ir_to_sync_plan.js +163 -0
- package/dist/compiler/ir_to_sync_plan.js.map +1 -0
- package/dist/compiler/parser.d.ts +99 -0
- package/dist/compiler/parser.js +556 -0
- package/dist/compiler/parser.js.map +1 -0
- package/dist/compiler/querier_graph.d.ts +42 -0
- package/dist/compiler/querier_graph.js +365 -0
- package/dist/compiler/querier_graph.js.map +1 -0
- package/dist/compiler/rows.d.ts +113 -0
- package/dist/compiler/rows.js +156 -0
- package/dist/compiler/rows.js.map +1 -0
- package/dist/compiler/scope.d.ts +22 -0
- package/dist/compiler/scope.js +47 -0
- package/dist/compiler/scope.js.map +1 -0
- package/dist/compiler/sqlite.d.ts +77 -0
- package/dist/compiler/sqlite.js +412 -0
- package/dist/compiler/sqlite.js.map +1 -0
- package/dist/compiler/table.d.ts +66 -0
- package/dist/compiler/table.js +67 -0
- package/dist/compiler/table.js.map +1 -0
- package/dist/errors.d.ts +4 -2
- package/dist/errors.js +16 -1
- package/dist/errors.js.map +1 -1
- package/dist/events/SqlEventDescriptor.js +1 -1
- package/dist/events/SqlEventDescriptor.js.map +1 -1
- package/dist/events/SqlEventSourceQuery.d.ts +1 -1
- package/dist/events/SqlEventSourceQuery.js +1 -2
- package/dist/events/SqlEventSourceQuery.js.map +1 -1
- package/dist/from_yaml.d.ts +28 -0
- package/dist/from_yaml.js +411 -0
- package/dist/from_yaml.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -1
- package/dist/json_schema.js +17 -1
- package/dist/json_schema.js.map +1 -1
- package/dist/request_functions.js.map +1 -1
- package/dist/schema-generators/DartSchemaGenerator.d.ts +3 -3
- package/dist/schema-generators/DartSchemaGenerator.js.map +1 -1
- package/dist/schema-generators/DotNetSchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/DotNetSchemaGenerator.js.map +1 -1
- package/dist/schema-generators/JsLegacySchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/JsLegacySchemaGenerator.js.map +1 -1
- package/dist/schema-generators/KotlinSchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/KotlinSchemaGenerator.js.map +1 -1
- package/dist/schema-generators/RoomSchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/RoomSchemaGenerator.js.map +1 -1
- package/dist/schema-generators/SchemaGenerator.d.ts +8 -3
- package/dist/schema-generators/SchemaGenerator.js +21 -14
- package/dist/schema-generators/SchemaGenerator.js.map +1 -1
- package/dist/schema-generators/SqlSchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/SqlSchemaGenerator.js.map +1 -1
- package/dist/schema-generators/SwiftSchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/SwiftSchemaGenerator.js.map +1 -1
- package/dist/schema-generators/TsSchemaGenerator.d.ts +2 -2
- package/dist/schema-generators/TsSchemaGenerator.js.map +1 -1
- package/dist/sql_functions.d.ts +4 -3
- package/dist/sql_functions.js +1 -1
- package/dist/sql_functions.js.map +1 -1
- package/dist/streams/filter.d.ts +34 -4
- package/dist/streams/filter.js +93 -23
- package/dist/streams/filter.js.map +1 -1
- package/dist/streams/from_sql.js +2 -5
- package/dist/streams/from_sql.js.map +1 -1
- package/dist/streams/parameter.d.ts +7 -6
- package/dist/streams/stream.d.ts +25 -15
- package/dist/streams/stream.js +59 -87
- package/dist/streams/stream.js.map +1 -1
- package/dist/streams/variant.d.ts +14 -21
- package/dist/streams/variant.js +68 -46
- package/dist/streams/variant.js.map +1 -1
- package/dist/sync_plan/engine/javascript.d.ts +6 -0
- package/dist/sync_plan/engine/javascript.js +208 -0
- package/dist/sync_plan/engine/javascript.js.map +1 -0
- package/dist/sync_plan/engine/scalar_expression_engine.d.ts +48 -0
- package/dist/sync_plan/engine/scalar_expression_engine.js +99 -0
- package/dist/sync_plan/engine/scalar_expression_engine.js.map +1 -0
- package/dist/sync_plan/engine/sqlite.d.ts +12 -0
- package/dist/sync_plan/engine/sqlite.js +53 -0
- package/dist/sync_plan/engine/sqlite.js.map +1 -0
- package/dist/sync_plan/evaluator/bucket_data_source.d.ts +24 -0
- package/dist/sync_plan/evaluator/bucket_data_source.js +139 -0
- package/dist/sync_plan/evaluator/bucket_data_source.js.map +1 -0
- package/dist/sync_plan/evaluator/bucket_source.d.ts +19 -0
- package/dist/sync_plan/evaluator/bucket_source.js +145 -0
- package/dist/sync_plan/evaluator/bucket_source.js.map +1 -0
- package/dist/sync_plan/evaluator/index.d.ts +17 -0
- package/dist/sync_plan/evaluator/index.js +32 -0
- package/dist/sync_plan/evaluator/index.js.map +1 -0
- package/dist/sync_plan/evaluator/parameter_evaluator.d.ts +138 -0
- package/dist/sync_plan/evaluator/parameter_evaluator.js +359 -0
- package/dist/sync_plan/evaluator/parameter_evaluator.js.map +1 -0
- package/dist/sync_plan/evaluator/parameter_index_lookup_creator.d.ts +20 -0
- package/dist/sync_plan/evaluator/parameter_index_lookup_creator.js +64 -0
- package/dist/sync_plan/evaluator/parameter_index_lookup_creator.js.map +1 -0
- package/dist/sync_plan/expression.d.ts +109 -0
- package/dist/sync_plan/expression.js +85 -0
- package/dist/sync_plan/expression.js.map +1 -0
- package/dist/sync_plan/expression_to_sql.d.ts +43 -0
- package/dist/sync_plan/expression_to_sql.js +190 -0
- package/dist/sync_plan/expression_to_sql.js.map +1 -0
- package/dist/sync_plan/expression_visitor.d.ts +57 -0
- package/dist/sync_plan/expression_visitor.js +181 -0
- package/dist/sync_plan/expression_visitor.js.map +1 -0
- package/dist/sync_plan/plan.d.ts +196 -0
- package/dist/sync_plan/plan.js +2 -0
- package/dist/sync_plan/plan.js.map +1 -0
- package/dist/sync_plan/schema_inference.d.ts +16 -0
- package/dist/sync_plan/schema_inference.js +123 -0
- package/dist/sync_plan/schema_inference.js.map +1 -0
- package/dist/sync_plan/serialize.d.ts +82 -0
- package/dist/sync_plan/serialize.js +214 -0
- package/dist/sync_plan/serialize.js.map +1 -0
- package/dist/types/custom_sqlite_value.d.ts +1 -1
- package/dist/types.d.ts +72 -29
- package/dist/types.js +30 -5
- package/dist/types.js.map +1 -1
- package/dist/utils.d.ts +10 -3
- package/dist/utils.js +26 -3
- package/dist/utils.js.map +1 -1
- package/package.json +4 -3
- package/schema/sync_rules.json +19 -3
package/dist/SqlSyncRules.js
CHANGED
|
@@ -1,21 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
import { SqlEventDescriptor } from './events/SqlEventDescriptor.js';
|
|
6
|
-
import { validateSyncRulesSchema } from './json_schema.js';
|
|
7
|
-
import { SqlBucketDescriptor } from './SqlBucketDescriptor.js';
|
|
8
|
-
import { isEvaluatedParameters, isEvaluatedRow, isEvaluationError } from './types.js';
|
|
9
|
-
import { syncStreamFromSql } from './streams/from_sql.js';
|
|
10
|
-
import { CompatibilityContext, CompatibilityEdition, CompatibilityOption, TimeValuePrecision } from './compatibility.js';
|
|
11
|
-
import { applyRowContext } from './utils.js';
|
|
12
|
-
const ACCEPT_POTENTIALLY_DANGEROUS_QUERIES = Symbol('ACCEPT_POTENTIALLY_DANGEROUS_QUERIES');
|
|
13
|
-
export class SqlSyncRules {
|
|
14
|
-
bucketSources = [];
|
|
15
|
-
eventDescriptors = [];
|
|
16
|
-
compatibility = CompatibilityContext.FULL_BACKWARDS_COMPATIBILITY;
|
|
17
|
-
content;
|
|
18
|
-
errors = [];
|
|
1
|
+
import { SyncRulesErrors, YamlError } from './errors.js';
|
|
2
|
+
import { SyncConfig } from './SyncConfig.js';
|
|
3
|
+
import { SyncConfigFromYaml } from './from_yaml.js';
|
|
4
|
+
export class SqlSyncRules extends SyncConfig {
|
|
19
5
|
static validate(yaml, options) {
|
|
20
6
|
try {
|
|
21
7
|
const rules = this.fromYaml(yaml, options);
|
|
@@ -34,364 +20,13 @@ export class SqlSyncRules {
|
|
|
34
20
|
}
|
|
35
21
|
}
|
|
36
22
|
static fromYaml(yaml, options) {
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
schema:
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
{
|
|
45
|
-
tag: '!accept_potentially_dangerous_queries',
|
|
46
|
-
resolve(_text, _onError) {
|
|
47
|
-
return ACCEPT_POTENTIALLY_DANGEROUS_QUERIES;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
]
|
|
51
|
-
});
|
|
52
|
-
const rules = new SqlSyncRules(yaml);
|
|
53
|
-
if (parsed.errors.length > 0) {
|
|
54
|
-
rules.errors.push(...parsed.errors.map((error) => {
|
|
55
|
-
return new YamlError(error);
|
|
56
|
-
}));
|
|
57
|
-
if (throwOnError) {
|
|
58
|
-
rules.throwOnError();
|
|
59
|
-
}
|
|
60
|
-
return rules;
|
|
61
|
-
}
|
|
62
|
-
const declaredOptions = parsed.get('config');
|
|
63
|
-
let compatibility = CompatibilityContext.FULL_BACKWARDS_COMPATIBILITY;
|
|
64
|
-
if (declaredOptions != null) {
|
|
65
|
-
const edition = (declaredOptions.get('edition') ?? CompatibilityEdition.LEGACY);
|
|
66
|
-
const options = new Map();
|
|
67
|
-
let maxTimeValuePrecision = undefined;
|
|
68
|
-
for (const entry of declaredOptions.items) {
|
|
69
|
-
const { key: { value: key }, value: { value } } = entry;
|
|
70
|
-
if (key == 'timestamp_max_precision') {
|
|
71
|
-
maxTimeValuePrecision = TimeValuePrecision.byName[value];
|
|
72
|
-
}
|
|
73
|
-
const option = CompatibilityOption.byName[key];
|
|
74
|
-
if (option) {
|
|
75
|
-
options.set(option, value);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
compatibility = new CompatibilityContext({ edition, overrides: options, maxTimeValuePrecision });
|
|
79
|
-
if (maxTimeValuePrecision && !compatibility.isEnabled(CompatibilityOption.timestampsIso8601)) {
|
|
80
|
-
rules.errors.push(new YamlError(new Error(`'timestamp_max_precision' requires 'timestamps_iso8601' to be enabled.`)));
|
|
81
|
-
}
|
|
82
|
-
rules.compatibility = compatibility;
|
|
83
|
-
}
|
|
84
|
-
// Bucket definitions using explicit parameter and data queries.
|
|
85
|
-
const bucketMap = parsed.get('bucket_definitions');
|
|
86
|
-
const streamMap = parsed.get('streams');
|
|
87
|
-
const definitionNames = new Set();
|
|
88
|
-
const checkUniqueName = (name, literal) => {
|
|
89
|
-
if (definitionNames.has(name)) {
|
|
90
|
-
rules.errors.push(this.tokenError(literal, 'Duplicate stream or bucket definition.'));
|
|
91
|
-
return false;
|
|
92
|
-
}
|
|
93
|
-
definitionNames.add(name);
|
|
94
|
-
return true;
|
|
95
|
-
};
|
|
96
|
-
if (bucketMap == null && streamMap == null) {
|
|
97
|
-
rules.errors.push(new YamlError(new Error(`'bucket_definitions' or 'streams' is required`)));
|
|
98
|
-
if (throwOnError) {
|
|
99
|
-
rules.throwOnError();
|
|
100
|
-
}
|
|
101
|
-
return rules;
|
|
102
|
-
}
|
|
103
|
-
for (let entry of bucketMap?.items ?? []) {
|
|
104
|
-
const { key: keyScalar, value } = entry;
|
|
105
|
-
const key = keyScalar.toString();
|
|
106
|
-
if (!checkUniqueName(key, keyScalar)) {
|
|
107
|
-
continue;
|
|
108
|
-
}
|
|
109
|
-
if (value == null || !(value instanceof YAMLMap)) {
|
|
110
|
-
rules.errors.push(this.tokenError(keyScalar, `'${key}' bucket definition must be an object`));
|
|
111
|
-
continue;
|
|
112
|
-
}
|
|
113
|
-
const accept_potentially_dangerous_queries = value.get('accept_potentially_dangerous_queries', true)?.value == true;
|
|
114
|
-
const parseOptionPriority = rules.parsePriority(value);
|
|
115
|
-
const queryOptions = {
|
|
116
|
-
...options,
|
|
117
|
-
accept_potentially_dangerous_queries,
|
|
118
|
-
priority: parseOptionPriority,
|
|
119
|
-
compatibility
|
|
120
|
-
};
|
|
121
|
-
const parameters = value.get('parameters', true);
|
|
122
|
-
const dataQueries = value.get('data', true);
|
|
123
|
-
const descriptor = new SqlBucketDescriptor(key);
|
|
124
|
-
if (parameters instanceof Scalar) {
|
|
125
|
-
rules.withScalar(parameters, (q) => {
|
|
126
|
-
return descriptor.addParameterQuery(q, queryOptions);
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
else if (parameters instanceof YAMLSeq) {
|
|
130
|
-
for (let item of parameters.items) {
|
|
131
|
-
rules.withScalar(item, (q) => {
|
|
132
|
-
return descriptor.addParameterQuery(q, queryOptions);
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
else {
|
|
137
|
-
descriptor.addParameterQuery('SELECT', queryOptions);
|
|
138
|
-
}
|
|
139
|
-
if (!(dataQueries instanceof YAMLSeq)) {
|
|
140
|
-
rules.errors.push(this.tokenError(dataQueries ?? value, `'data' must be an array`));
|
|
141
|
-
continue;
|
|
142
|
-
}
|
|
143
|
-
for (let query of dataQueries.items) {
|
|
144
|
-
rules.withScalar(query, (q) => {
|
|
145
|
-
return descriptor.addDataQuery(q, queryOptions, compatibility);
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
rules.bucketSources.push(descriptor);
|
|
149
|
-
}
|
|
150
|
-
for (const entry of streamMap?.items ?? []) {
|
|
151
|
-
const { key: keyScalar, value } = entry;
|
|
152
|
-
const key = keyScalar.toString();
|
|
153
|
-
if (!checkUniqueName(key, keyScalar)) {
|
|
154
|
-
continue;
|
|
155
|
-
}
|
|
156
|
-
const accept_potentially_dangerous_queries = value.get('accept_potentially_dangerous_queries', true)?.value == true;
|
|
157
|
-
const queryOptions = {
|
|
158
|
-
...options,
|
|
159
|
-
accept_potentially_dangerous_queries,
|
|
160
|
-
priority: rules.parsePriority(value),
|
|
161
|
-
auto_subscribe: value.get('auto_subscribe', true)?.value == true,
|
|
162
|
-
compatibility
|
|
163
|
-
};
|
|
164
|
-
const data = value.get('query', true);
|
|
165
|
-
if (data instanceof Scalar) {
|
|
166
|
-
rules.withScalar(data, (q) => {
|
|
167
|
-
const [parsed, errors] = syncStreamFromSql(key, q, queryOptions);
|
|
168
|
-
rules.bucketSources.push(parsed);
|
|
169
|
-
return {
|
|
170
|
-
parsed: true,
|
|
171
|
-
errors
|
|
172
|
-
};
|
|
173
|
-
});
|
|
174
|
-
}
|
|
175
|
-
else {
|
|
176
|
-
rules.errors.push(this.tokenError(data, 'Must be a string.'));
|
|
177
|
-
continue;
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
const eventMap = parsed.get('event_definitions');
|
|
181
|
-
for (const event of eventMap?.items ?? []) {
|
|
182
|
-
const { key, value } = event;
|
|
183
|
-
if (false == value instanceof YAMLMap) {
|
|
184
|
-
rules.errors.push(new YamlError(new Error(`Event definitions must be objects.`)));
|
|
185
|
-
continue;
|
|
186
|
-
}
|
|
187
|
-
const payloads = value.get('payloads');
|
|
188
|
-
if (false == payloads instanceof YAMLSeq) {
|
|
189
|
-
rules.errors.push(new YamlError(new Error(`Event definition payloads must be an array.`)));
|
|
190
|
-
continue;
|
|
191
|
-
}
|
|
192
|
-
const eventDescriptor = new SqlEventDescriptor(key.toString(), compatibility);
|
|
193
|
-
for (let item of payloads.items) {
|
|
194
|
-
if (!isScalar(item)) {
|
|
195
|
-
rules.errors.push(new YamlError(new Error(`Payload queries for events must be scalar.`)));
|
|
196
|
-
continue;
|
|
197
|
-
}
|
|
198
|
-
rules.withScalar(item, (q) => {
|
|
199
|
-
return eventDescriptor.addSourceQuery(q, options);
|
|
200
|
-
});
|
|
201
|
-
}
|
|
202
|
-
rules.eventDescriptors.push(eventDescriptor);
|
|
203
|
-
}
|
|
204
|
-
// Validate that there are no additional properties.
|
|
205
|
-
// Since these errors don't contain line numbers, do this last.
|
|
206
|
-
const valid = validateSyncRulesSchema(parsed.toJSON());
|
|
207
|
-
if (!valid) {
|
|
208
|
-
rules.errors.push(...validateSyncRulesSchema.errors.map((e) => {
|
|
209
|
-
return new YamlError(e);
|
|
210
|
-
}));
|
|
211
|
-
}
|
|
212
|
-
if (throwOnError) {
|
|
213
|
-
rules.throwOnError();
|
|
214
|
-
}
|
|
215
|
-
return rules;
|
|
216
|
-
}
|
|
217
|
-
throwOnError() {
|
|
218
|
-
if (this.errors.filter((e) => e.type != 'warning').length > 0) {
|
|
219
|
-
throw new SyncRulesErrors(this.errors);
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
static tokenError(token, message) {
|
|
223
|
-
const start = token?.srcToken?.offset ?? 0;
|
|
224
|
-
const end = start + 1;
|
|
225
|
-
return new YamlError(new Error(message), { start, end });
|
|
226
|
-
}
|
|
227
|
-
withScalar(scalar, cb) {
|
|
228
|
-
const value = scalar.toString();
|
|
229
|
-
const wrapped = (value) => {
|
|
230
|
-
try {
|
|
231
|
-
return cb(value);
|
|
232
|
-
}
|
|
233
|
-
catch (e) {
|
|
234
|
-
return {
|
|
235
|
-
parsed: false,
|
|
236
|
-
errors: [e]
|
|
237
|
-
};
|
|
238
|
-
}
|
|
239
|
-
};
|
|
240
|
-
const result = wrapped(value);
|
|
241
|
-
for (let err of result.errors) {
|
|
242
|
-
let sourceOffset = scalar.srcToken.offset;
|
|
243
|
-
if (scalar.type == Scalar.QUOTE_DOUBLE || scalar.type == Scalar.QUOTE_SINGLE) {
|
|
244
|
-
// TODO: Is there a better way to do this?
|
|
245
|
-
sourceOffset += 1;
|
|
246
|
-
}
|
|
247
|
-
let offset;
|
|
248
|
-
let end;
|
|
249
|
-
if (err instanceof SqlRuleError && err.location) {
|
|
250
|
-
offset = err.location.start + sourceOffset;
|
|
251
|
-
end = err.location.end + sourceOffset;
|
|
252
|
-
}
|
|
253
|
-
else if (typeof err.token?._location?.start == 'number') {
|
|
254
|
-
offset = sourceOffset + err.token?._location?.start;
|
|
255
|
-
end = sourceOffset + err.token?._location?.end;
|
|
256
|
-
}
|
|
257
|
-
else {
|
|
258
|
-
offset = sourceOffset;
|
|
259
|
-
end = sourceOffset + Math.max(value.length, 1);
|
|
260
|
-
}
|
|
261
|
-
const pos = { start: offset, end };
|
|
262
|
-
this.errors.push(new YamlError(err, pos));
|
|
263
|
-
}
|
|
264
|
-
return result;
|
|
265
|
-
}
|
|
266
|
-
constructor(content) {
|
|
267
|
-
this.content = content;
|
|
268
|
-
}
|
|
269
|
-
applyRowContext(source) {
|
|
270
|
-
return applyRowContext(source, this.compatibility);
|
|
271
|
-
}
|
|
272
|
-
/**
|
|
273
|
-
* Throws errors.
|
|
274
|
-
*/
|
|
275
|
-
evaluateRow(options) {
|
|
276
|
-
const { results, errors } = this.evaluateRowWithErrors(options);
|
|
277
|
-
if (errors.length > 0) {
|
|
278
|
-
throw new Error(errors[0].error);
|
|
279
|
-
}
|
|
280
|
-
return results;
|
|
281
|
-
}
|
|
282
|
-
evaluateRowWithErrors(options) {
|
|
283
|
-
const resolvedOptions = this.compatibility.isEnabled(CompatibilityOption.versionedBucketIds)
|
|
284
|
-
? options
|
|
285
|
-
: {
|
|
286
|
-
...options,
|
|
287
|
-
// Disable bucket id transformer when the option is unused.
|
|
288
|
-
bucketIdTransformer: (id) => id
|
|
289
|
-
};
|
|
290
|
-
let rawResults = [];
|
|
291
|
-
for (let source of this.bucketSources) {
|
|
292
|
-
rawResults.push(...source.evaluateRow(resolvedOptions));
|
|
293
|
-
}
|
|
294
|
-
const results = rawResults.filter(isEvaluatedRow);
|
|
295
|
-
const errors = rawResults.filter(isEvaluationError);
|
|
296
|
-
return { results, errors };
|
|
297
|
-
}
|
|
298
|
-
/**
|
|
299
|
-
* Throws errors.
|
|
300
|
-
*/
|
|
301
|
-
evaluateParameterRow(table, row) {
|
|
302
|
-
const { results, errors } = this.evaluateParameterRowWithErrors(table, row);
|
|
303
|
-
if (errors.length > 0) {
|
|
304
|
-
throw new Error(errors[0].error);
|
|
305
|
-
}
|
|
306
|
-
return results;
|
|
307
|
-
}
|
|
308
|
-
evaluateParameterRowWithErrors(table, row) {
|
|
309
|
-
let rawResults = [];
|
|
310
|
-
for (let source of this.bucketSources) {
|
|
311
|
-
rawResults.push(...source.evaluateParameterRow(table, row));
|
|
312
|
-
}
|
|
313
|
-
const results = rawResults.filter(isEvaluatedParameters);
|
|
314
|
-
const errors = rawResults.filter(isEvaluationError);
|
|
315
|
-
return { results, errors };
|
|
316
|
-
}
|
|
317
|
-
getBucketParameterQuerier(options) {
|
|
318
|
-
const resolvedOptions = this.compatibility.isEnabled(CompatibilityOption.versionedBucketIds)
|
|
319
|
-
? options
|
|
320
|
-
: {
|
|
321
|
-
...options,
|
|
322
|
-
// Disable bucket id transformer when the option is unused.
|
|
323
|
-
bucketIdTransformer: (id) => id
|
|
324
|
-
};
|
|
325
|
-
const queriers = [];
|
|
326
|
-
const errors = [];
|
|
327
|
-
const pending = { queriers, errors };
|
|
328
|
-
for (const source of this.bucketSources) {
|
|
329
|
-
if ((source.subscribedToByDefault && resolvedOptions.hasDefaultStreams) ||
|
|
330
|
-
source.name in resolvedOptions.streams) {
|
|
331
|
-
source.pushBucketParameterQueriers(pending, resolvedOptions);
|
|
332
|
-
}
|
|
333
|
-
}
|
|
334
|
-
const querier = mergeBucketParameterQueriers(queriers);
|
|
335
|
-
return { querier, errors };
|
|
336
|
-
}
|
|
337
|
-
hasDynamicBucketQueries() {
|
|
338
|
-
return this.bucketSources.some((s) => s.hasDynamicBucketQueries());
|
|
339
|
-
}
|
|
340
|
-
getSourceTables() {
|
|
341
|
-
const sourceTables = new Map();
|
|
342
|
-
for (const bucket of this.bucketSources) {
|
|
343
|
-
for (const r of bucket.getSourceTables()) {
|
|
344
|
-
const key = `${r.connectionTag}.${r.schema}.${r.tablePattern}`;
|
|
345
|
-
sourceTables.set(key, r);
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
for (const event of this.eventDescriptors) {
|
|
349
|
-
for (const r of event.getSourceTables()) {
|
|
350
|
-
const key = `${r.connectionTag}.${r.schema}.${r.tablePattern}`;
|
|
351
|
-
sourceTables.set(key, r);
|
|
352
|
-
}
|
|
353
|
-
}
|
|
354
|
-
return [...sourceTables.values()];
|
|
355
|
-
}
|
|
356
|
-
getEventTables() {
|
|
357
|
-
const eventTables = new Map();
|
|
358
|
-
for (const event of this.eventDescriptors) {
|
|
359
|
-
for (const r of event.getSourceTables()) {
|
|
360
|
-
const key = `${r.connectionTag}.${r.schema}.${r.tablePattern}`;
|
|
361
|
-
eventTables.set(key, r);
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
return [...eventTables.values()];
|
|
365
|
-
}
|
|
366
|
-
tableTriggersEvent(table) {
|
|
367
|
-
return this.eventDescriptors.some((bucket) => bucket.tableTriggersEvent(table));
|
|
368
|
-
}
|
|
369
|
-
tableSyncsData(table) {
|
|
370
|
-
return this.bucketSources.some((b) => b.tableSyncsData(table));
|
|
371
|
-
}
|
|
372
|
-
tableSyncsParameters(table) {
|
|
373
|
-
return this.bucketSources.some((b) => b.tableSyncsParameters(table));
|
|
374
|
-
}
|
|
375
|
-
debugGetOutputTables() {
|
|
376
|
-
let result = {};
|
|
377
|
-
for (let bucket of this.bucketSources) {
|
|
378
|
-
bucket.debugWriteOutputTables(result);
|
|
379
|
-
}
|
|
380
|
-
return result;
|
|
381
|
-
}
|
|
382
|
-
parsePriority(value) {
|
|
383
|
-
if (value.has('priority')) {
|
|
384
|
-
const priorityValue = value.get('priority', true);
|
|
385
|
-
if (typeof priorityValue.value != 'number' || !isValidPriority(priorityValue.value)) {
|
|
386
|
-
this.errors.push(SqlSyncRules.tokenError(priorityValue, 'Invalid priority, expected a number between 0 and 3 (inclusive).'));
|
|
387
|
-
}
|
|
388
|
-
else {
|
|
389
|
-
return priorityValue.value;
|
|
390
|
-
}
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
static versionedBucketIdTransformer(version) {
|
|
394
|
-
return (bucketId) => `${version}#${bucketId}`;
|
|
23
|
+
const parser = new SyncConfigFromYaml({
|
|
24
|
+
throwOnError: options.throwOnError ?? true,
|
|
25
|
+
allowNewSyncCompiler: options.allowNewSyncCompiler ?? false,
|
|
26
|
+
schema: options.schema,
|
|
27
|
+
defaultSchema: options.defaultSchema
|
|
28
|
+
}, yaml);
|
|
29
|
+
return parser.read();
|
|
395
30
|
}
|
|
396
31
|
}
|
|
397
32
|
//# sourceMappingURL=SqlSyncRules.js.map
|
package/dist/SqlSyncRules.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SqlSyncRules.js","sourceRoot":"","sources":["../src/SqlSyncRules.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SqlSyncRules.js","sourceRoot":"","sources":["../src/SqlSyncRules.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAEzD,OAAO,EAAE,UAAU,EAAwB,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AA6DpD,MAAM,OAAO,YAAa,SAAQ,UAAU;IAC1C,MAAM,CAAC,QAAQ,CAAC,IAAY,EAAE,OAAyB;QACrD,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YAC3C,OAAO,KAAK,CAAC,MAAM,CAAC;QACtB,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,IAAI,CAAC,YAAY,eAAe,EAAE,CAAC;gBACjC,OAAO,CAAC,CAAC,MAAM,CAAC;YAClB,CAAC;iBAAM,IAAI,CAAC,YAAY,SAAS,EAAE,CAAC;gBAClC,OAAO,CAAC,CAAC,CAAC,CAAC;YACb,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,IAAY,EAAE,OAAyB;QACrD,MAAM,MAAM,GAAG,IAAI,kBAAkB,CACnC;YACE,YAAY,EAAE,OAAO,CAAC,YAAY,IAAI,IAAI;YAC1C,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,IAAI,KAAK;YAC3D,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,aAAa,EAAE,OAAO,CAAC,aAAa;SACrC,EACD,IAAI,CACL,CAAC;QAEF,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;CACF"}
|
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
import { SelectFromStatement } from 'pgsql-ast-parser';
|
|
2
2
|
import { BucketDescription, BucketPriority } from './BucketDescription.js';
|
|
3
|
+
import { CreateSourceParams } from './BucketSource.js';
|
|
3
4
|
import { SqlRuleError } from './errors.js';
|
|
4
|
-
import {
|
|
5
|
+
import { BucketDataScope } from './HydrationState.js';
|
|
6
|
+
import { BucketDataSource, BucketParameterQuerierSource } from './index.js';
|
|
7
|
+
import { SourceTableInterface } from './SourceTableInterface.js';
|
|
8
|
+
import { TablePattern } from './TablePattern.js';
|
|
9
|
+
import { ParameterValueClause, QueryParseOptions, RequestParameters } from './types.js';
|
|
5
10
|
export interface StaticSqlParameterQueryOptions {
|
|
6
11
|
sql: string;
|
|
7
12
|
parameterExtractors: Record<string, ParameterValueClause>;
|
|
@@ -10,6 +15,7 @@ export interface StaticSqlParameterQueryOptions {
|
|
|
10
15
|
bucketParameters: string[];
|
|
11
16
|
queryId: string;
|
|
12
17
|
filter: ParameterValueClause | undefined;
|
|
18
|
+
querierDataSource: BucketDataSource;
|
|
13
19
|
errors?: SqlRuleError[];
|
|
14
20
|
}
|
|
15
21
|
/**
|
|
@@ -19,7 +25,7 @@ export interface StaticSqlParameterQueryOptions {
|
|
|
19
25
|
* SELECT token_parameters.user_id as user_id WHERE token_parameters.is_admin
|
|
20
26
|
*/
|
|
21
27
|
export declare class StaticSqlParameterQuery {
|
|
22
|
-
static fromSql(descriptorName: string, sql: string, q: SelectFromStatement, options: QueryParseOptions, queryId: string): StaticSqlParameterQuery;
|
|
28
|
+
static fromSql(descriptorName: string, sql: string, q: SelectFromStatement, options: QueryParseOptions, queryId: string, querierDataSource: BucketDataSource): StaticSqlParameterQuery;
|
|
23
29
|
/**
|
|
24
30
|
* Raw source sql query, for debugging purposes.
|
|
25
31
|
*/
|
|
@@ -55,9 +61,13 @@ export declare class StaticSqlParameterQuery {
|
|
|
55
61
|
* undefined if the clause is not valid.
|
|
56
62
|
*/
|
|
57
63
|
readonly filter: ParameterValueClause | undefined;
|
|
64
|
+
readonly querierDataSource: BucketDataSource;
|
|
58
65
|
readonly errors: SqlRuleError[];
|
|
59
66
|
constructor(options: StaticSqlParameterQueryOptions);
|
|
60
|
-
|
|
67
|
+
getSourceTables(): Set<TablePattern>;
|
|
68
|
+
tableSyncsParameters(_table: SourceTableInterface): boolean;
|
|
69
|
+
createParameterQuerierSource(params: CreateSourceParams): BucketParameterQuerierSource;
|
|
70
|
+
getStaticBucketDescriptions(parameters: RequestParameters, bucketSourceScope: BucketDataScope): BucketDescription[];
|
|
61
71
|
get hasAuthenticatedBucketParameters(): boolean;
|
|
62
72
|
get usesUnauthenticatedRequestParameters(): boolean;
|
|
63
73
|
get usesDangerousRequestParameters(): boolean;
|
|
@@ -2,7 +2,7 @@ import { DEFAULT_BUCKET_PRIORITY } from './BucketDescription.js';
|
|
|
2
2
|
import { SqlRuleError } from './errors.js';
|
|
3
3
|
import { AvailableTable, SqlTools } from './sql_filters.js';
|
|
4
4
|
import { checkUnsupportedFeatures, isClauseError, sqliteBool } from './sql_support.js';
|
|
5
|
-
import {
|
|
5
|
+
import { buildBucketName, isJsonValue, serializeBucketParameters } from './utils.js';
|
|
6
6
|
import { DetectRequestParameters } from './validators.js';
|
|
7
7
|
/**
|
|
8
8
|
* Represents a bucket parameter query without any tables, e.g.:
|
|
@@ -11,7 +11,7 @@ import { DetectRequestParameters } from './validators.js';
|
|
|
11
11
|
* SELECT token_parameters.user_id as user_id WHERE token_parameters.is_admin
|
|
12
12
|
*/
|
|
13
13
|
export class StaticSqlParameterQuery {
|
|
14
|
-
static fromSql(descriptorName, sql, q, options, queryId) {
|
|
14
|
+
static fromSql(descriptorName, sql, q, options, queryId, querierDataSource) {
|
|
15
15
|
let errors = [];
|
|
16
16
|
errors.push(...checkUnsupportedFeatures(sql, q));
|
|
17
17
|
const tools = new SqlTools({
|
|
@@ -58,6 +58,7 @@ export class StaticSqlParameterQuery {
|
|
|
58
58
|
priority: priority ?? DEFAULT_BUCKET_PRIORITY,
|
|
59
59
|
filter: isClauseError(filter) ? undefined : filter,
|
|
60
60
|
queryId,
|
|
61
|
+
querierDataSource,
|
|
61
62
|
errors
|
|
62
63
|
});
|
|
63
64
|
if (query.usesDangerousRequestParameters && !options?.accept_potentially_dangerous_queries) {
|
|
@@ -102,6 +103,7 @@ export class StaticSqlParameterQuery {
|
|
|
102
103
|
* undefined if the clause is not valid.
|
|
103
104
|
*/
|
|
104
105
|
filter;
|
|
106
|
+
querierDataSource;
|
|
105
107
|
errors;
|
|
106
108
|
constructor(options) {
|
|
107
109
|
this.sql = options.sql;
|
|
@@ -111,9 +113,40 @@ export class StaticSqlParameterQuery {
|
|
|
111
113
|
this.bucketParameters = options.bucketParameters;
|
|
112
114
|
this.queryId = options.queryId;
|
|
113
115
|
this.filter = options.filter;
|
|
116
|
+
this.querierDataSource = options.querierDataSource;
|
|
114
117
|
this.errors = options.errors ?? [];
|
|
115
118
|
}
|
|
116
|
-
|
|
119
|
+
getSourceTables() {
|
|
120
|
+
return new Set();
|
|
121
|
+
}
|
|
122
|
+
tableSyncsParameters(_table) {
|
|
123
|
+
return false;
|
|
124
|
+
}
|
|
125
|
+
createParameterQuerierSource(params) {
|
|
126
|
+
const hydrationState = params.hydrationState;
|
|
127
|
+
const bucketScope = hydrationState.getBucketSourceScope(this.querierDataSource);
|
|
128
|
+
return {
|
|
129
|
+
pushBucketParameterQueriers: (result, options) => {
|
|
130
|
+
const staticBuckets = this.getStaticBucketDescriptions(options.globalParameters, bucketScope).map((desc) => {
|
|
131
|
+
return {
|
|
132
|
+
...desc,
|
|
133
|
+
definition: this.descriptorName,
|
|
134
|
+
inclusion_reasons: ['default']
|
|
135
|
+
};
|
|
136
|
+
});
|
|
137
|
+
if (staticBuckets.length == 0) {
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
const staticQuerier = {
|
|
141
|
+
staticBuckets,
|
|
142
|
+
hasDynamicBuckets: false,
|
|
143
|
+
queryDynamicBucketDescriptions: async () => []
|
|
144
|
+
};
|
|
145
|
+
result.queriers.push(staticQuerier);
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
getStaticBucketDescriptions(parameters, bucketSourceScope) {
|
|
117
150
|
if (this.filter == null) {
|
|
118
151
|
// Error in filter clause
|
|
119
152
|
return [];
|
|
@@ -134,9 +167,10 @@ export class StaticSqlParameterQuery {
|
|
|
134
167
|
return [];
|
|
135
168
|
}
|
|
136
169
|
}
|
|
170
|
+
const serializedParamters = serializeBucketParameters(this.bucketParameters, result);
|
|
137
171
|
return [
|
|
138
172
|
{
|
|
139
|
-
bucket:
|
|
173
|
+
bucket: buildBucketName(bucketSourceScope, serializedParamters),
|
|
140
174
|
priority: this.priority
|
|
141
175
|
}
|
|
142
176
|
];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StaticSqlParameterQuery.js","sourceRoot":"","sources":["../src/StaticSqlParameterQuery.ts"],"names":[],"mappings":"AACA,OAAO,EAAqC,uBAAuB,
|
|
1
|
+
{"version":3,"file":"StaticSqlParameterQuery.js","sourceRoot":"","sources":["../src/StaticSqlParameterQuery.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { BucketDataSource, BucketSource, CreateSourceParams, ParameterIndexLookupCreator } from './BucketSource.js';
|
|
2
|
+
import { CompatibilityContext } from './compatibility.js';
|
|
3
|
+
import { YamlError } from './errors.js';
|
|
4
|
+
import { SqlEventDescriptor } from './events/SqlEventDescriptor.js';
|
|
5
|
+
import { HydratedSyncRules } from './HydratedSyncRules.js';
|
|
6
|
+
import { SourceTableInterface } from './SourceTableInterface.js';
|
|
7
|
+
import { TablePattern } from './TablePattern.js';
|
|
8
|
+
import { SqliteInputValue, SqliteRow, SqliteValue } from './types.js';
|
|
9
|
+
/**
|
|
10
|
+
* A class describing how the sync process has been configured (i.e. which buckets and parameters to create and how to
|
|
11
|
+
* resolve buckets for connections).
|
|
12
|
+
*/
|
|
13
|
+
export declare abstract class SyncConfig {
|
|
14
|
+
bucketDataSources: BucketDataSource[];
|
|
15
|
+
bucketParameterLookupSources: ParameterIndexLookupCreator[];
|
|
16
|
+
bucketSources: BucketSource[];
|
|
17
|
+
compatibility: CompatibilityContext;
|
|
18
|
+
eventDescriptors: SqlEventDescriptor[];
|
|
19
|
+
/**
|
|
20
|
+
* The (YAML-based) source contents from which these sync rules have been derived.
|
|
21
|
+
*/
|
|
22
|
+
content: string;
|
|
23
|
+
constructor(content: string);
|
|
24
|
+
/**
|
|
25
|
+
* Hydrate the sync rule definitions with persisted state into runnable sync rules.
|
|
26
|
+
*
|
|
27
|
+
* @param params.hydrationState Transforms bucket ids based on persisted state. May omit for tests.
|
|
28
|
+
*/
|
|
29
|
+
hydrate(params?: CreateSourceParams): HydratedSyncRules;
|
|
30
|
+
applyRowContext<MaybeToast extends undefined = never>(source: SqliteRow<SqliteInputValue | MaybeToast>): SqliteRow<SqliteValue | MaybeToast>;
|
|
31
|
+
protected writeSourceTables(sourceTables: Map<String, TablePattern>): void;
|
|
32
|
+
getSourceTables(): TablePattern[];
|
|
33
|
+
getEventTables(): TablePattern[];
|
|
34
|
+
tableTriggersEvent(table: SourceTableInterface): boolean;
|
|
35
|
+
tableSyncsData(table: SourceTableInterface): boolean;
|
|
36
|
+
tableSyncsParameters(table: SourceTableInterface): boolean;
|
|
37
|
+
debugGetOutputTables(): Record<string, any[]>;
|
|
38
|
+
debugRepresentation(): any[];
|
|
39
|
+
}
|
|
40
|
+
export interface SyncConfigWithErrors {
|
|
41
|
+
config: SyncConfig;
|
|
42
|
+
errors: YamlError[];
|
|
43
|
+
}
|