@aws-amplify/datastore-storage-adapter 2.0.64 → 2.0.67
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/CHANGELOG.md +14 -0
- package/dist/aws-amplify-datastore-sqlite-adapter-expo.js +424 -255
- package/dist/aws-amplify-datastore-sqlite-adapter-expo.js.map +1 -1
- package/dist/aws-amplify-datastore-sqlite-adapter-expo.min.js +1 -1
- package/dist/aws-amplify-datastore-sqlite-adapter-expo.min.js.map +1 -1
- package/dist/aws-amplify-datastore-storage-adapter.js +418 -248
- package/dist/aws-amplify-datastore-storage-adapter.js.map +1 -1
- package/dist/aws-amplify-datastore-storage-adapter.min.js +1 -1
- package/dist/aws-amplify-datastore-storage-adapter.min.js.map +1 -1
- package/lib/common/SQLiteUtils.d.ts +1 -1
- package/lib/index.js +1 -0
- package/lib/index.js.map +1 -1
- package/lib-esm/common/SQLiteUtils.d.ts +1 -1
- package/lib-esm/index.js +1 -0
- package/lib-esm/index.js.map +1 -1
- package/package.json +4 -4
- package/src/index.ts +2 -0
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/ExpoSQLiteAdapter/ExpoSQLiteAdapter.js +0 -9
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/ExpoSQLiteAdapter/ExpoSQLiteDatabase.js +0 -205
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/SQLiteAdapter/SQLiteAdapter.js +0 -9
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/SQLiteAdapter/SQLiteDatabase.js +0 -116
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/common/CommonSQLiteAdapter.js +0 -242
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/common/SQLiteUtils.js +0 -385
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/common/constants.js +0 -6
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/common/types.js +0 -2
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/cjs/index.js +0 -8
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/ExpoSQLiteAdapter/ExpoSQLiteAdapter.d.ts +0 -3
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/ExpoSQLiteAdapter/ExpoSQLiteAdapter.js +0 -6
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/ExpoSQLiteAdapter/ExpoSQLiteDatabase.d.ts +0 -17
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/ExpoSQLiteAdapter/ExpoSQLiteDatabase.js +0 -203
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/SQLiteAdapter/SQLiteAdapter.d.ts +0 -3
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/SQLiteAdapter/SQLiteAdapter.js +0 -6
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/SQLiteAdapter/SQLiteDatabase.d.ts +0 -17
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/SQLiteAdapter/SQLiteDatabase.js +0 -113
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/CommonSQLiteAdapter.d.ts +0 -23
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/CommonSQLiteAdapter.js +0 -238
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/SQLiteUtils.d.ts +0 -40
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/SQLiteUtils.js +0 -367
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/constants.d.ts +0 -1
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/constants.js +0 -3
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/types.d.ts +0 -16
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/common/types.js +0 -1
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/index.d.ts +0 -2
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/esm/index.js +0 -4
- package/.rollup.cache/home/runner/work/amplify-js/amplify-js/amplify-js/packages/datastore-storage-adapter/dist/meta/cjs.tsbuildinfo +0 -1
|
@@ -1,367 +0,0 @@
|
|
|
1
|
-
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
import { QueryOne, isGraphQLScalarType, isModelAttributeAuth, isModelFieldType, isPredicateGroup, isPredicateObj, isTargetNameAssociation, utils, } from '@aws-amplify/datastore';
|
|
4
|
-
const { USER, isNonModelConstructor, isModelConstructor } = utils;
|
|
5
|
-
const keysFromModel = model => Object.keys(model)
|
|
6
|
-
.map(k => `"${k}"`)
|
|
7
|
-
.join(', ');
|
|
8
|
-
const valuesFromModel = (model) => {
|
|
9
|
-
const values = Object.values(model).map(prepareValueForDML);
|
|
10
|
-
const paramaterized = values.map(() => '?').join(', ');
|
|
11
|
-
return [paramaterized, values];
|
|
12
|
-
};
|
|
13
|
-
const updateSet = model => {
|
|
14
|
-
const values = [];
|
|
15
|
-
const paramaterized = Object.entries(model)
|
|
16
|
-
.filter(([k]) => k !== 'id')
|
|
17
|
-
.map(([k, v]) => {
|
|
18
|
-
values.push(prepareValueForDML(v));
|
|
19
|
-
return `"${k}"=?`;
|
|
20
|
-
})
|
|
21
|
-
.join(', ');
|
|
22
|
-
return [paramaterized, values];
|
|
23
|
-
};
|
|
24
|
-
function prepareValueForDML(value) {
|
|
25
|
-
const scalarTypes = ['string', 'number', 'boolean'];
|
|
26
|
-
const isScalarType = value === null || value === undefined || scalarTypes.includes(typeof value);
|
|
27
|
-
if (isScalarType) {
|
|
28
|
-
return value;
|
|
29
|
-
}
|
|
30
|
-
const isObjectType = typeof value === 'object' &&
|
|
31
|
-
(Object.getPrototypeOf(value).constructor === Object ||
|
|
32
|
-
isNonModelConstructor(Object.getPrototypeOf(value).constructor) ||
|
|
33
|
-
isModelConstructor(Object.getPrototypeOf(value).constructor));
|
|
34
|
-
if (Array.isArray(value) || isObjectType) {
|
|
35
|
-
return JSON.stringify(value);
|
|
36
|
-
}
|
|
37
|
-
return `${value}`;
|
|
38
|
-
}
|
|
39
|
-
export function getSQLiteType(scalar) {
|
|
40
|
-
switch (scalar) {
|
|
41
|
-
case 'Boolean':
|
|
42
|
-
case 'Int':
|
|
43
|
-
case 'AWSTimestamp':
|
|
44
|
-
return 'INTEGER';
|
|
45
|
-
case 'ID':
|
|
46
|
-
case 'String':
|
|
47
|
-
case 'AWSDate':
|
|
48
|
-
case 'AWSTime':
|
|
49
|
-
case 'AWSDateTime':
|
|
50
|
-
case 'AWSEmail':
|
|
51
|
-
case 'AWSJSON':
|
|
52
|
-
case 'AWSURL':
|
|
53
|
-
case 'AWSPhone':
|
|
54
|
-
case 'AWSIPAddress':
|
|
55
|
-
return 'TEXT';
|
|
56
|
-
case 'Float':
|
|
57
|
-
return 'REAL';
|
|
58
|
-
default: {
|
|
59
|
-
const _ = scalar;
|
|
60
|
-
throw new Error(`unknown type ${scalar}`);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
export function generateSchemaStatements(schema) {
|
|
65
|
-
return Object.keys(schema.namespaces).flatMap(namespaceName => {
|
|
66
|
-
const namespace = schema.namespaces[namespaceName];
|
|
67
|
-
const isUserModel = namespaceName === USER;
|
|
68
|
-
return Object.values(namespace.models).map(model => modelCreateTableStatement(model, isUserModel));
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
export const implicitAuthFieldsForModel = (model) => {
|
|
72
|
-
if (!model.attributes || !model.attributes.length) {
|
|
73
|
-
return [];
|
|
74
|
-
}
|
|
75
|
-
const authRules = model.attributes.find(isModelAttributeAuth);
|
|
76
|
-
if (!authRules) {
|
|
77
|
-
return [];
|
|
78
|
-
}
|
|
79
|
-
const authFieldsForModel = authRules.properties.rules
|
|
80
|
-
.filter((rule) => rule.ownerField || rule.groupsField)
|
|
81
|
-
.map((rule) => rule.ownerField || rule.groupsField);
|
|
82
|
-
return authFieldsForModel.filter((authField) => {
|
|
83
|
-
const authFieldExplicitlyDefined = Object.values(model.fields).find((f) => f.name === authField);
|
|
84
|
-
return !authFieldExplicitlyDefined;
|
|
85
|
-
});
|
|
86
|
-
};
|
|
87
|
-
export function modelCreateTableStatement(model, userModel = false) {
|
|
88
|
-
// implicitly defined auth fields, e.g., `owner`, `groupsField`, etc.
|
|
89
|
-
const implicitAuthFields = implicitAuthFieldsForModel(model);
|
|
90
|
-
let fields = Object.values(model.fields).reduce((acc, field) => {
|
|
91
|
-
if (isGraphQLScalarType(field.type)) {
|
|
92
|
-
if (field.name === 'id') {
|
|
93
|
-
return [...acc, '"id" PRIMARY KEY NOT NULL'];
|
|
94
|
-
}
|
|
95
|
-
let columnParam = `"${field.name}" ${getSQLiteType(field.type)}`;
|
|
96
|
-
if (field.isRequired) {
|
|
97
|
-
columnParam += ' NOT NULL';
|
|
98
|
-
}
|
|
99
|
-
return [...acc, `${columnParam}`];
|
|
100
|
-
}
|
|
101
|
-
if (isModelFieldType(field.type)) {
|
|
102
|
-
let columnParam = `"${field.name}" TEXT`;
|
|
103
|
-
// add targetName as well as field name for BELONGS_TO relations
|
|
104
|
-
if (isTargetNameAssociation(field.association)) {
|
|
105
|
-
// check if this field has been explicitly defined in the model
|
|
106
|
-
const fkDefinedInModel = Object.values(model.fields).find((f) => f.name === field?.association?.targetName);
|
|
107
|
-
// if the FK is not explicitly defined in the model, we have to add it here
|
|
108
|
-
if (!fkDefinedInModel) {
|
|
109
|
-
const required = field.isRequired ? ' NOT NULL' : '';
|
|
110
|
-
columnParam += `, "${field.association.targetName}" TEXT${required}`;
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
// ignore isRequired param for model fields, since they will not contain
|
|
114
|
-
// the related data locally
|
|
115
|
-
return [...acc, `${columnParam}`];
|
|
116
|
-
}
|
|
117
|
-
// default to TEXT
|
|
118
|
-
let columnParam = `"${field.name}" TEXT`;
|
|
119
|
-
if (field.isRequired) {
|
|
120
|
-
columnParam += ' NOT NULL';
|
|
121
|
-
}
|
|
122
|
-
return [...acc, `${columnParam}`];
|
|
123
|
-
}, []);
|
|
124
|
-
implicitAuthFields.forEach((authField) => {
|
|
125
|
-
fields.push(`${authField} TEXT`);
|
|
126
|
-
});
|
|
127
|
-
if (userModel) {
|
|
128
|
-
fields = [
|
|
129
|
-
...fields,
|
|
130
|
-
`"_version" INTEGER`,
|
|
131
|
-
`"_lastChangedAt" INTEGER`,
|
|
132
|
-
`"_deleted" INTEGER`,
|
|
133
|
-
];
|
|
134
|
-
}
|
|
135
|
-
const createTableStatement = `CREATE TABLE IF NOT EXISTS "${model.name}" (${fields.join(', ')});`;
|
|
136
|
-
return createTableStatement;
|
|
137
|
-
}
|
|
138
|
-
export function modelInsertStatement(model, tableName) {
|
|
139
|
-
const keys = keysFromModel(model);
|
|
140
|
-
const [paramaterized, values] = valuesFromModel(model);
|
|
141
|
-
const insertStatement = `INSERT INTO "${tableName}" (${keys}) VALUES (${paramaterized})`;
|
|
142
|
-
return [insertStatement, values];
|
|
143
|
-
}
|
|
144
|
-
export function modelUpdateStatement(model, tableName) {
|
|
145
|
-
const [paramaterized, values] = updateSet(model);
|
|
146
|
-
const updateStatement = `UPDATE "${tableName}" SET ${paramaterized} WHERE id=?`;
|
|
147
|
-
return [updateStatement, [...values, model.id]];
|
|
148
|
-
}
|
|
149
|
-
export function queryByIdStatement(id, tableName) {
|
|
150
|
-
return [`SELECT * FROM "${tableName}" WHERE "id" = ?`, [id]];
|
|
151
|
-
}
|
|
152
|
-
/*
|
|
153
|
-
Predicates supported by DataStore:
|
|
154
|
-
|
|
155
|
-
Strings: eq | ne | le | lt | ge | gt | contains | notContains | beginsWith | between
|
|
156
|
-
Numbers: eq | ne | le | lt | ge | gt | between
|
|
157
|
-
Lists: contains | notContains
|
|
158
|
-
*/
|
|
159
|
-
const comparisonOperatorMap = {
|
|
160
|
-
eq: '=',
|
|
161
|
-
ne: '!=',
|
|
162
|
-
le: '<=',
|
|
163
|
-
lt: '<',
|
|
164
|
-
ge: '>=',
|
|
165
|
-
gt: '>',
|
|
166
|
-
};
|
|
167
|
-
const logicalOperatorMap = {
|
|
168
|
-
beginsWith: '= 1',
|
|
169
|
-
contains: '> 0',
|
|
170
|
-
notContains: '= 0',
|
|
171
|
-
between: 'BETWEEN',
|
|
172
|
-
};
|
|
173
|
-
const arrayOperatorMap = {
|
|
174
|
-
in: 'IN',
|
|
175
|
-
notIn: 'NOT IN',
|
|
176
|
-
};
|
|
177
|
-
/**
|
|
178
|
-
* If the given (operator, operand) indicate the need for a special `NULL` comparison,
|
|
179
|
-
* that `WHERE` clause condition will be returned. If not special `NULL` handling is
|
|
180
|
-
* needed, `null` will be returned, and the caller should construct the `WHERE`
|
|
181
|
-
* clause component using the normal operator map(s) and parameterization.
|
|
182
|
-
*
|
|
183
|
-
* @param operator "beginsWith" | "contains" | "notContains" | "between"
|
|
184
|
-
* | "eq" | "ne" | "le" | "lt" | "ge" | "gt"
|
|
185
|
-
* @param operand any
|
|
186
|
-
* @returns (string | null) The `WHERE` clause component or `null` if N/A.
|
|
187
|
-
*/
|
|
188
|
-
function buildSpecialNullComparison(field, operator, operand) {
|
|
189
|
-
if (operand === null || operand === undefined) {
|
|
190
|
-
if (operator === 'eq') {
|
|
191
|
-
return `"${field}" IS NULL`;
|
|
192
|
-
}
|
|
193
|
-
else if (operator === 'ne') {
|
|
194
|
-
return `"${field}" IS NOT NULL`;
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
// no special null handling required
|
|
198
|
-
return null;
|
|
199
|
-
}
|
|
200
|
-
/**
|
|
201
|
-
* Builds a special SQL clause that always evaluates to true or false.
|
|
202
|
-
* Used for edge cases like empty arrays in 'in'/'notIn' operators.
|
|
203
|
-
*
|
|
204
|
-
* @param operator The operator ('in' or 'notIn')
|
|
205
|
-
* @returns A ParameterizedStatement that always evaluates to true or false
|
|
206
|
-
*/
|
|
207
|
-
function buildSpecialAlwaysStatement(operator) {
|
|
208
|
-
// Empty array: nothing can be IN or NOT IN an empty set
|
|
209
|
-
// For 'in': always false (nothing matches)
|
|
210
|
-
// For 'notIn': always true (everything doesn't match)
|
|
211
|
-
return operator === 'in' ? ['1 = 0', []] : ['1 = 1', []];
|
|
212
|
-
}
|
|
213
|
-
export const whereConditionFromPredicateObject = ({ field, operator, operand, }) => {
|
|
214
|
-
const specialNullClause = buildSpecialNullComparison(field, operator, operand);
|
|
215
|
-
if (specialNullClause) {
|
|
216
|
-
return [specialNullClause, []];
|
|
217
|
-
}
|
|
218
|
-
const comparisonOperator = comparisonOperatorMap[operator];
|
|
219
|
-
if (comparisonOperator) {
|
|
220
|
-
return [`"${field}" ${comparisonOperator} ?`, [operand]];
|
|
221
|
-
}
|
|
222
|
-
// Handle array operators ('in' and 'notIn')
|
|
223
|
-
const arrayOperator = arrayOperatorMap[operator];
|
|
224
|
-
if (arrayOperator) {
|
|
225
|
-
if (!Array.isArray(operand)) {
|
|
226
|
-
throw new Error(`Operand for ${operator} must be an array`);
|
|
227
|
-
}
|
|
228
|
-
if (operand.length === 0) {
|
|
229
|
-
return buildSpecialAlwaysStatement(operator);
|
|
230
|
-
}
|
|
231
|
-
// Prepare values for SQL (handle complex types)
|
|
232
|
-
const preparedValues = operand.map(prepareValueForDML);
|
|
233
|
-
const placeholders = preparedValues.map(() => '?').join(', ');
|
|
234
|
-
return [`"${field}" ${arrayOperator} (${placeholders})`, preparedValues];
|
|
235
|
-
}
|
|
236
|
-
const logicalOperatorKey = operator;
|
|
237
|
-
const logicalOperator = logicalOperatorMap[logicalOperatorKey];
|
|
238
|
-
let statement;
|
|
239
|
-
if (logicalOperator) {
|
|
240
|
-
let rightExp = [];
|
|
241
|
-
switch (logicalOperatorKey) {
|
|
242
|
-
case 'between':
|
|
243
|
-
rightExp = operand; // operand is a 2-tuple
|
|
244
|
-
statement = [
|
|
245
|
-
`"${field}" ${logicalOperator} ${rightExp
|
|
246
|
-
.map(_ => '?')
|
|
247
|
-
.join(' AND ')}`,
|
|
248
|
-
rightExp,
|
|
249
|
-
];
|
|
250
|
-
break;
|
|
251
|
-
case 'beginsWith':
|
|
252
|
-
case 'contains':
|
|
253
|
-
case 'notContains':
|
|
254
|
-
statement = [`instr("${field}", ?) ${logicalOperator}`, [operand]];
|
|
255
|
-
break;
|
|
256
|
-
default: {
|
|
257
|
-
const _ = logicalOperatorKey;
|
|
258
|
-
// Incorrect WHERE clause can result in data loss
|
|
259
|
-
throw new Error('Cannot map predicate to a valid WHERE clause');
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
return statement;
|
|
263
|
-
}
|
|
264
|
-
// Incorrect WHERE clause can result in data loss
|
|
265
|
-
throw new Error('Cannot map predicate to a valid WHERE clause');
|
|
266
|
-
};
|
|
267
|
-
export function whereClauseFromPredicate(predicate) {
|
|
268
|
-
const result = [];
|
|
269
|
-
const params = [];
|
|
270
|
-
recurse(predicate, result, params);
|
|
271
|
-
const whereClause = `WHERE ${result.join(' ')}`;
|
|
272
|
-
return [whereClause, params];
|
|
273
|
-
function recurse(recursedPredicate, recursedResult = [], recursedParams = []) {
|
|
274
|
-
if (isPredicateGroup(recursedPredicate)) {
|
|
275
|
-
const { type: groupType, predicates: groupPredicates } = recursedPredicate;
|
|
276
|
-
let filterType = '';
|
|
277
|
-
let isNegation = false;
|
|
278
|
-
switch (groupType) {
|
|
279
|
-
case 'not':
|
|
280
|
-
isNegation = true;
|
|
281
|
-
break;
|
|
282
|
-
case 'and':
|
|
283
|
-
filterType = 'AND';
|
|
284
|
-
break;
|
|
285
|
-
case 'or':
|
|
286
|
-
filterType = 'OR';
|
|
287
|
-
break;
|
|
288
|
-
default: {
|
|
289
|
-
const _ = groupType;
|
|
290
|
-
throw new Error(`Invalid ${groupType}`);
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
const groupResult = [];
|
|
294
|
-
for (const p of groupPredicates) {
|
|
295
|
-
recurse(p, groupResult, recursedParams);
|
|
296
|
-
}
|
|
297
|
-
recursedResult.push(`${isNegation ? 'NOT' : ''}(${groupResult.join(` ${filterType} `)})`);
|
|
298
|
-
}
|
|
299
|
-
else if (isPredicateObj(recursedPredicate)) {
|
|
300
|
-
const [condition, conditionParams] = whereConditionFromPredicateObject(recursedPredicate);
|
|
301
|
-
recursedResult.push(condition);
|
|
302
|
-
recursedParams.push(...conditionParams);
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
const sortDirectionMap = {
|
|
307
|
-
ASCENDING: 'ASC',
|
|
308
|
-
DESCENDING: 'DESC',
|
|
309
|
-
};
|
|
310
|
-
export function orderByClauseFromSort(sortPredicate = []) {
|
|
311
|
-
const orderByParts = sortPredicate.map(({ field, sortDirection }) => `"${String(field)}" ${sortDirectionMap[sortDirection]}`);
|
|
312
|
-
// We always sort by _rowid_ last
|
|
313
|
-
orderByParts.push(`_rowid_ ${sortDirectionMap.ASCENDING}`);
|
|
314
|
-
return `ORDER BY ${orderByParts.join(', ')}`;
|
|
315
|
-
}
|
|
316
|
-
export function limitClauseFromPagination(limit, page = 0) {
|
|
317
|
-
const params = [limit];
|
|
318
|
-
let clause = 'LIMIT ?';
|
|
319
|
-
if (page) {
|
|
320
|
-
const offset = limit * page;
|
|
321
|
-
params.push(offset);
|
|
322
|
-
clause += ' OFFSET ?';
|
|
323
|
-
}
|
|
324
|
-
return [clause, params];
|
|
325
|
-
}
|
|
326
|
-
export function queryAllStatement(tableName, predicate, sort, limit, page) {
|
|
327
|
-
let statement = `SELECT * FROM "${tableName}"`;
|
|
328
|
-
const params = [];
|
|
329
|
-
if (predicate && predicate.predicates.length) {
|
|
330
|
-
const [whereClause, whereParams] = whereClauseFromPredicate(predicate);
|
|
331
|
-
statement += ` ${whereClause}`;
|
|
332
|
-
params.push(...whereParams);
|
|
333
|
-
}
|
|
334
|
-
const orderByClause = orderByClauseFromSort(sort);
|
|
335
|
-
statement += ` ${orderByClause}`;
|
|
336
|
-
if (limit) {
|
|
337
|
-
const [limitClause, limitParams] = limitClauseFromPagination(limit, page);
|
|
338
|
-
statement += ` ${limitClause}`;
|
|
339
|
-
params.push(...limitParams);
|
|
340
|
-
}
|
|
341
|
-
return [statement, params];
|
|
342
|
-
}
|
|
343
|
-
export function queryOneStatement(firstOrLast, tableName) {
|
|
344
|
-
if (firstOrLast === QueryOne.FIRST) {
|
|
345
|
-
// ORDER BY rowid will no longer work as expected if a customer has
|
|
346
|
-
// a field by that name in their schema. We may want to enforce it
|
|
347
|
-
// as a reserved keyword in Codegen
|
|
348
|
-
return [`SELECT * FROM ${tableName} ORDER BY _rowid_ LIMIT 1`, []];
|
|
349
|
-
}
|
|
350
|
-
else {
|
|
351
|
-
return [`SELECT * FROM ${tableName} ORDER BY _rowid_ DESC LIMIT 1`, []];
|
|
352
|
-
}
|
|
353
|
-
}
|
|
354
|
-
export function deleteByIdStatement(id, tableName) {
|
|
355
|
-
const deleteStatement = `DELETE FROM "${tableName}" WHERE "id"=?`;
|
|
356
|
-
return [deleteStatement, [id]];
|
|
357
|
-
}
|
|
358
|
-
export function deleteByPredicateStatement(tableName, predicate) {
|
|
359
|
-
let statement = `DELETE FROM "${tableName}"`;
|
|
360
|
-
const params = [];
|
|
361
|
-
if (predicate && predicate.predicates.length) {
|
|
362
|
-
const [whereClause, whereParams] = whereClauseFromPredicate(predicate);
|
|
363
|
-
statement += ` ${whereClause}`;
|
|
364
|
-
params.push(...whereParams);
|
|
365
|
-
}
|
|
366
|
-
return [statement, params];
|
|
367
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const DB_NAME = "AmplifyDatastore";
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { ModelInstanceMetadata, PersistentModel } from '@aws-amplify/datastore';
|
|
2
|
-
export interface CommonSQLiteDatabase {
|
|
3
|
-
init(): Promise<void>;
|
|
4
|
-
createSchema(statements: string[]): Promise<void>;
|
|
5
|
-
clear(): Promise<void>;
|
|
6
|
-
get<T extends PersistentModel>(statement: string, params: (string | number)[]): Promise<T>;
|
|
7
|
-
getAll<T extends PersistentModel>(statement: string, params: (string | number)[]): Promise<T[]>;
|
|
8
|
-
save(statement: string, params: (string | number)[]): Promise<void>;
|
|
9
|
-
batchQuery<T = any>(queryParameterizedStatement: Set<ParameterizedStatement>): Promise<T[]>;
|
|
10
|
-
batchSave(saveParameterizedStatements: Set<ParameterizedStatement>, deleteParameterizedStatements?: Set<ParameterizedStatement>): Promise<void>;
|
|
11
|
-
selectAndDelete<T = any>(queryParameterizedStatement: ParameterizedStatement, deleteParameterizedStatement: ParameterizedStatement): Promise<T[]>;
|
|
12
|
-
}
|
|
13
|
-
export type ParameterizedStatement = [string, any[]];
|
|
14
|
-
export type ModelInstanceMetadataWithId = ModelInstanceMetadata & {
|
|
15
|
-
id: string;
|
|
16
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|