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