@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,113 +0,0 @@
|
|
|
1
|
-
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
import SQLite from 'react-native-sqlite-storage';
|
|
4
|
-
import { ConsoleLogger } from '@aws-amplify/core';
|
|
5
|
-
import { DB_NAME } from '../common/constants';
|
|
6
|
-
const logger = new ConsoleLogger('SQLiteDatabase');
|
|
7
|
-
SQLite.enablePromise(true);
|
|
8
|
-
if (ConsoleLogger.LOG_LEVEL === 'DEBUG') {
|
|
9
|
-
SQLite.DEBUG(true);
|
|
10
|
-
}
|
|
11
|
-
/*
|
|
12
|
-
|
|
13
|
-
Note:
|
|
14
|
-
I purposely avoided using arrow functions () => {} in this class,
|
|
15
|
-
Because I ran into issues with them in some of the SQLite method callbacks
|
|
16
|
-
|
|
17
|
-
Also, even though the SQLite library is promisified, certain operations
|
|
18
|
-
only work correctly with callbacks. Specifically, any time you need to
|
|
19
|
-
get the result of an `executeSql` command inside of a transaction
|
|
20
|
-
(see the batchQuery method below)
|
|
21
|
-
|
|
22
|
-
*/
|
|
23
|
-
class SQLiteDatabase {
|
|
24
|
-
async init() {
|
|
25
|
-
// only open database once.
|
|
26
|
-
if (!this.db) {
|
|
27
|
-
this.db = await SQLite.openDatabase({
|
|
28
|
-
name: DB_NAME,
|
|
29
|
-
location: 'default',
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
async createSchema(statements) {
|
|
34
|
-
await this.executeStatements(statements);
|
|
35
|
-
}
|
|
36
|
-
async clear() {
|
|
37
|
-
await this.closeDB();
|
|
38
|
-
logger.debug('Deleting database');
|
|
39
|
-
await SQLite.deleteDatabase({ name: DB_NAME, location: 'default' });
|
|
40
|
-
logger.debug('Database deleted');
|
|
41
|
-
}
|
|
42
|
-
async get(statement, params) {
|
|
43
|
-
const results = await this.getAll(statement, params);
|
|
44
|
-
return results[0];
|
|
45
|
-
}
|
|
46
|
-
async getAll(statement, params) {
|
|
47
|
-
const [resultSet] = await this.db.executeSql(statement, params);
|
|
48
|
-
const result = resultSet &&
|
|
49
|
-
resultSet.rows &&
|
|
50
|
-
resultSet.rows.length &&
|
|
51
|
-
resultSet.rows.raw &&
|
|
52
|
-
resultSet.rows.raw();
|
|
53
|
-
return result || [];
|
|
54
|
-
}
|
|
55
|
-
async save(statement, params) {
|
|
56
|
-
await this.db.executeSql(statement, params);
|
|
57
|
-
}
|
|
58
|
-
async batchQuery(queryParameterizedStatements) {
|
|
59
|
-
const results = [];
|
|
60
|
-
await this.db.readTransaction(tx => {
|
|
61
|
-
for (const [statement, params] of queryParameterizedStatements) {
|
|
62
|
-
tx.executeSql(statement, params, (_, res) => {
|
|
63
|
-
results.push(res.rows.raw()[0]);
|
|
64
|
-
}, logger.warn);
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
return results;
|
|
68
|
-
}
|
|
69
|
-
async batchSave(saveParameterizedStatements, deleteParameterizedStatements) {
|
|
70
|
-
await this.db.transaction(tx => {
|
|
71
|
-
for (const [statement, params] of saveParameterizedStatements) {
|
|
72
|
-
tx.executeSql(statement, params);
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
if (deleteParameterizedStatements) {
|
|
76
|
-
await this.db.transaction(tx => {
|
|
77
|
-
for (const [statement, params] of deleteParameterizedStatements) {
|
|
78
|
-
tx.executeSql(statement, params);
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
async selectAndDelete(queryParameterizedStatement, deleteParameterizedStatement) {
|
|
84
|
-
let results = [];
|
|
85
|
-
const [queryStatement, queryParams] = queryParameterizedStatement;
|
|
86
|
-
const [deleteStatement, deleteParams] = deleteParameterizedStatement;
|
|
87
|
-
await this.db.transaction(tx => {
|
|
88
|
-
tx.executeSql(queryStatement, queryParams, (_, res) => {
|
|
89
|
-
results = res.rows.raw();
|
|
90
|
-
}, logger.warn);
|
|
91
|
-
tx.executeSql(deleteStatement, deleteParams, () => {
|
|
92
|
-
// no-op
|
|
93
|
-
}, logger.warn);
|
|
94
|
-
});
|
|
95
|
-
return results;
|
|
96
|
-
}
|
|
97
|
-
async executeStatements(statements) {
|
|
98
|
-
await this.db.transaction(tx => {
|
|
99
|
-
for (const statement of statements) {
|
|
100
|
-
tx.executeSql(statement);
|
|
101
|
-
}
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
async closeDB() {
|
|
105
|
-
if (this.db) {
|
|
106
|
-
logger.debug('Closing Database');
|
|
107
|
-
await this.db.close();
|
|
108
|
-
logger.debug('Database closed');
|
|
109
|
-
this.db = undefined;
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
export default SQLiteDatabase;
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { InternalSchema, ModelInstanceCreator, ModelPredicate, NAMESPACES, NamespaceResolver, OpType, PaginationInput, PersistentModel, PersistentModelConstructor, QueryOne, StorageAdapter } from '@aws-amplify/datastore';
|
|
2
|
-
import { CommonSQLiteDatabase, ModelInstanceMetadataWithId } from './types';
|
|
3
|
-
export declare class CommonSQLiteAdapter implements StorageAdapter {
|
|
4
|
-
private schema;
|
|
5
|
-
private namespaceResolver;
|
|
6
|
-
private modelInstanceCreator;
|
|
7
|
-
private getModelConstructorByModelName;
|
|
8
|
-
private db;
|
|
9
|
-
private initPromise;
|
|
10
|
-
private resolve;
|
|
11
|
-
private reject;
|
|
12
|
-
constructor(db: CommonSQLiteDatabase);
|
|
13
|
-
setUp(theSchema: InternalSchema, namespaceResolver: NamespaceResolver, modelInstanceCreator: ModelInstanceCreator, getModelConstructorByModelName: (namsespaceName: NAMESPACES, modelName: string) => PersistentModelConstructor<any>): Promise<void>;
|
|
14
|
-
clear(): Promise<void>;
|
|
15
|
-
save<T extends PersistentModel>(model: T, condition?: ModelPredicate<T>): Promise<[T, OpType.INSERT | OpType.UPDATE][]>;
|
|
16
|
-
private load;
|
|
17
|
-
query<T extends PersistentModel>(modelConstructor: PersistentModelConstructor<T>, predicate?: ModelPredicate<T>, pagination?: PaginationInput<T>): Promise<T[]>;
|
|
18
|
-
private getById;
|
|
19
|
-
private idFromPredicate;
|
|
20
|
-
queryOne<T extends PersistentModel>(modelConstructor: PersistentModelConstructor<T>, firstOrLast?: QueryOne): Promise<T | undefined>;
|
|
21
|
-
delete<T extends PersistentModel>(modelOrModelConstructor: T | PersistentModelConstructor<T>, condition?: ModelPredicate<T>): Promise<[T[], T[]]>;
|
|
22
|
-
batchSave<T extends PersistentModel>(modelConstructor: PersistentModelConstructor<any>, items: ModelInstanceMetadataWithId[]): Promise<[T, OpType][]>;
|
|
23
|
-
}
|
|
@@ -1,238 +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 { ModelPredicateCreator, ModelSortPredicateCreator, OpType, QueryOne, isPredicateObj, utils, } from '@aws-amplify/datastore';
|
|
5
|
-
import { deleteByIdStatement, deleteByPredicateStatement, generateSchemaStatements, modelInsertStatement, modelUpdateStatement, queryAllStatement, queryByIdStatement, queryOneStatement, } from '../common/SQLiteUtils';
|
|
6
|
-
const { traverseModel, validatePredicate, isModelConstructor } = utils;
|
|
7
|
-
const logger = new ConsoleLogger('DataStore');
|
|
8
|
-
export class CommonSQLiteAdapter {
|
|
9
|
-
constructor(db) {
|
|
10
|
-
this.db = db;
|
|
11
|
-
}
|
|
12
|
-
async setUp(theSchema, namespaceResolver, modelInstanceCreator, getModelConstructorByModelName) {
|
|
13
|
-
if (!this.initPromise) {
|
|
14
|
-
this.initPromise = new Promise((_resolve, _reject) => {
|
|
15
|
-
this.resolve = _resolve;
|
|
16
|
-
this.reject = _reject;
|
|
17
|
-
});
|
|
18
|
-
}
|
|
19
|
-
else {
|
|
20
|
-
await this.initPromise;
|
|
21
|
-
return;
|
|
22
|
-
}
|
|
23
|
-
this.schema = theSchema;
|
|
24
|
-
this.namespaceResolver = namespaceResolver;
|
|
25
|
-
this.modelInstanceCreator = modelInstanceCreator;
|
|
26
|
-
this.getModelConstructorByModelName = getModelConstructorByModelName;
|
|
27
|
-
try {
|
|
28
|
-
const usesCPKCodegen = Object.values(this.schema.namespaces.user?.models || {}).some(model => Object.values(model.fields).some((field) =>
|
|
29
|
-
// eslint-disable-next-line no-prototype-builtins
|
|
30
|
-
field.association?.hasOwnProperty('targetNames')));
|
|
31
|
-
if (usesCPKCodegen) {
|
|
32
|
-
logger.error('The SQLite adapter does not support schemas using custom primary key. Set `graphQLTransformer.respectPrimaryKeyAttributesOnConnectionField in `amplify/cli.json` to false to disable custom primary key. To regenerate your API, add or remove an empty newline to your GraphQL schema (to change the computed hash) then run `amplify push`.');
|
|
33
|
-
}
|
|
34
|
-
await this.db.init();
|
|
35
|
-
const statements = generateSchemaStatements(this.schema);
|
|
36
|
-
await this.db.createSchema(statements);
|
|
37
|
-
this.resolve();
|
|
38
|
-
}
|
|
39
|
-
catch (error) {
|
|
40
|
-
this.reject(error);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
async clear() {
|
|
44
|
-
await this.db.clear();
|
|
45
|
-
this.initPromise = undefined;
|
|
46
|
-
}
|
|
47
|
-
async save(model, condition) {
|
|
48
|
-
const modelConstructor = Object.getPrototypeOf(model)
|
|
49
|
-
.constructor;
|
|
50
|
-
const { name: tableName } = modelConstructor;
|
|
51
|
-
const connectedModels = traverseModel(modelConstructor.name, model, this.schema.namespaces[this.namespaceResolver(modelConstructor)], this.modelInstanceCreator, this.getModelConstructorByModelName);
|
|
52
|
-
const connectionStoreNames = Object.values(connectedModels).map(({ modelName, item, instance }) => {
|
|
53
|
-
return { modelName, item, instance };
|
|
54
|
-
});
|
|
55
|
-
const [queryStatement, params] = queryByIdStatement(model.id, tableName);
|
|
56
|
-
const fromDB = await this.db.get(queryStatement, params);
|
|
57
|
-
if (condition && fromDB) {
|
|
58
|
-
const predicates = ModelPredicateCreator.getPredicates(condition);
|
|
59
|
-
const { predicates: predicateObjs, type } = predicates;
|
|
60
|
-
const isValid = validatePredicate(fromDB, type, predicateObjs);
|
|
61
|
-
if (!isValid) {
|
|
62
|
-
const msg = 'Conditional update failed';
|
|
63
|
-
logger.error(msg, { model: fromDB, condition: predicateObjs });
|
|
64
|
-
throw new Error(msg);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
const result = [];
|
|
68
|
-
const saveStatements = new Set();
|
|
69
|
-
for await (const resItem of connectionStoreNames) {
|
|
70
|
-
const { modelName, item, instance } = resItem;
|
|
71
|
-
const { id } = item;
|
|
72
|
-
const [queryStatementForRestItem, paramsForRestItem] = queryByIdStatement(id, modelName);
|
|
73
|
-
const fromDBForRestItem = await this.db.get(queryStatementForRestItem, paramsForRestItem);
|
|
74
|
-
const opType = fromDBForRestItem === undefined ? OpType.INSERT : OpType.UPDATE;
|
|
75
|
-
const saveStatement = fromDBForRestItem
|
|
76
|
-
? modelUpdateStatement(instance, modelName)
|
|
77
|
-
: modelInsertStatement(instance, modelName);
|
|
78
|
-
if (id === model.id || opType === OpType.INSERT) {
|
|
79
|
-
saveStatements.add(saveStatement);
|
|
80
|
-
result.push([instance, opType]);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
await this.db.batchSave(saveStatements);
|
|
84
|
-
return result;
|
|
85
|
-
}
|
|
86
|
-
async load(namespaceName, srcModelName, records) {
|
|
87
|
-
const namespace = this.schema.namespaces[namespaceName];
|
|
88
|
-
const relations = namespace.relationships[srcModelName].relationTypes;
|
|
89
|
-
const connectionTableNames = relations.map(({ modelName }) => modelName);
|
|
90
|
-
const modelConstructor = this.getModelConstructorByModelName(namespaceName, srcModelName);
|
|
91
|
-
if (connectionTableNames.length === 0) {
|
|
92
|
-
return records.map(record => this.modelInstanceCreator(modelConstructor, record));
|
|
93
|
-
}
|
|
94
|
-
// Remove related-model fields. They're all `null` in the database,
|
|
95
|
-
// and any that happen to be required will result in a false validation
|
|
96
|
-
// error when DataStore attempts to initialize with `null`.
|
|
97
|
-
// These fields aren't actually needed here. DataStore will use the FK's
|
|
98
|
-
// from the schema model.
|
|
99
|
-
return records.map(record => {
|
|
100
|
-
for (const r of relations) {
|
|
101
|
-
delete record[r.fieldName];
|
|
102
|
-
}
|
|
103
|
-
return this.modelInstanceCreator(modelConstructor, record);
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
|
-
async query(modelConstructor, predicate, pagination) {
|
|
107
|
-
const { name: tableName } = modelConstructor;
|
|
108
|
-
const namespaceName = this.namespaceResolver(modelConstructor);
|
|
109
|
-
const predicates = predicate && ModelPredicateCreator.getPredicates(predicate);
|
|
110
|
-
const sortPredicates = pagination &&
|
|
111
|
-
pagination.sort &&
|
|
112
|
-
ModelSortPredicateCreator.getPredicates(pagination.sort);
|
|
113
|
-
const limit = pagination && pagination.limit;
|
|
114
|
-
const page = limit && pagination.page;
|
|
115
|
-
const queryById = predicates && this.idFromPredicate(predicates);
|
|
116
|
-
const records = (await (async () => {
|
|
117
|
-
if (queryById) {
|
|
118
|
-
const record = await this.getById(tableName, queryById);
|
|
119
|
-
return record ? [record] : [];
|
|
120
|
-
}
|
|
121
|
-
const [queryStatement, params] = queryAllStatement(tableName, predicates, sortPredicates, limit, page);
|
|
122
|
-
return this.db.getAll(queryStatement, params);
|
|
123
|
-
})());
|
|
124
|
-
return this.load(namespaceName, modelConstructor.name, records);
|
|
125
|
-
}
|
|
126
|
-
async getById(tableName, id) {
|
|
127
|
-
const [queryStatement, params] = queryByIdStatement(id, tableName);
|
|
128
|
-
const record = await this.db.get(queryStatement, params);
|
|
129
|
-
return record;
|
|
130
|
-
}
|
|
131
|
-
idFromPredicate(predicates) {
|
|
132
|
-
const { predicates: predicateObjs } = predicates;
|
|
133
|
-
const idPredicate = predicateObjs.length === 1 &&
|
|
134
|
-
predicateObjs.find(p => isPredicateObj(p) && p.field === 'id' && p.operator === 'eq');
|
|
135
|
-
return idPredicate && idPredicate.operand;
|
|
136
|
-
}
|
|
137
|
-
async queryOne(modelConstructor, firstOrLast = QueryOne.FIRST) {
|
|
138
|
-
const { name: tableName } = modelConstructor;
|
|
139
|
-
const [queryStatement, params] = queryOneStatement(firstOrLast, tableName);
|
|
140
|
-
const result = await this.db.get(queryStatement, params);
|
|
141
|
-
const modelInstance = result && this.modelInstanceCreator(modelConstructor, result);
|
|
142
|
-
return modelInstance;
|
|
143
|
-
}
|
|
144
|
-
// Currently does not cascade
|
|
145
|
-
// TODO: use FKs in relations and have `ON DELETE CASCADE` set
|
|
146
|
-
// For Has Many and Has One relations to have SQL handle cascades automatically
|
|
147
|
-
async delete(modelOrModelConstructor, condition) {
|
|
148
|
-
if (isModelConstructor(modelOrModelConstructor)) {
|
|
149
|
-
const modelConstructor = modelOrModelConstructor;
|
|
150
|
-
const namespaceName = this.namespaceResolver(modelConstructor);
|
|
151
|
-
const { name: tableName } = modelConstructor;
|
|
152
|
-
const predicates = condition && ModelPredicateCreator.getPredicates(condition);
|
|
153
|
-
const queryStatement = queryAllStatement(tableName, predicates);
|
|
154
|
-
const deleteStatement = deleteByPredicateStatement(tableName, predicates);
|
|
155
|
-
const models = await this.db.selectAndDelete(queryStatement, deleteStatement);
|
|
156
|
-
const modelInstances = await this.load(namespaceName, modelConstructor.name, models);
|
|
157
|
-
return [modelInstances, modelInstances];
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
const model = modelOrModelConstructor;
|
|
161
|
-
const modelConstructor = Object.getPrototypeOf(model)
|
|
162
|
-
.constructor;
|
|
163
|
-
const { name: tableName } = modelConstructor;
|
|
164
|
-
if (condition) {
|
|
165
|
-
const [queryStatement, params] = queryByIdStatement(model.id, tableName);
|
|
166
|
-
const fromDB = await this.db.get(queryStatement, params);
|
|
167
|
-
if (fromDB === undefined) {
|
|
168
|
-
const msg = 'Model instance not found in storage';
|
|
169
|
-
logger.warn(msg, { model });
|
|
170
|
-
return [[model], []];
|
|
171
|
-
}
|
|
172
|
-
const predicates = ModelPredicateCreator.getPredicates(condition);
|
|
173
|
-
const { predicates: predicateObjs, type } = predicates;
|
|
174
|
-
const isValid = validatePredicate(fromDB, type, predicateObjs);
|
|
175
|
-
if (!isValid) {
|
|
176
|
-
const msg = 'Conditional update failed';
|
|
177
|
-
logger.error(msg, { model: fromDB, condition: predicateObjs });
|
|
178
|
-
throw new Error(msg);
|
|
179
|
-
}
|
|
180
|
-
const [deleteStatement, deleteParams] = deleteByIdStatement(model.id, tableName);
|
|
181
|
-
await this.db.save(deleteStatement, deleteParams);
|
|
182
|
-
return [[model], [model]];
|
|
183
|
-
}
|
|
184
|
-
else {
|
|
185
|
-
const [deleteStatement, params] = deleteByIdStatement(model.id, tableName);
|
|
186
|
-
await this.db.save(deleteStatement, params);
|
|
187
|
-
return [[model], [model]];
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
async batchSave(modelConstructor, items) {
|
|
192
|
-
const { name: tableName } = modelConstructor;
|
|
193
|
-
const result = [];
|
|
194
|
-
const itemsToSave = [];
|
|
195
|
-
// To determine whether an item should result in an insert or update operation
|
|
196
|
-
// We first need to query the local DB on the item id
|
|
197
|
-
const queryStatements = new Set();
|
|
198
|
-
// Deletes don't need to be queried first, because if the item doesn't exist,
|
|
199
|
-
// the delete operation will be a no-op
|
|
200
|
-
const deleteStatements = new Set();
|
|
201
|
-
const saveStatements = new Set();
|
|
202
|
-
for (const item of items) {
|
|
203
|
-
const connectedModels = traverseModel(modelConstructor.name, this.modelInstanceCreator(modelConstructor, item), this.schema.namespaces[this.namespaceResolver(modelConstructor)], this.modelInstanceCreator, this.getModelConstructorByModelName);
|
|
204
|
-
const { id, _deleted } = item;
|
|
205
|
-
const { instance } = connectedModels.find(({ instance: connectedModelInstance }) => connectedModelInstance.id === id);
|
|
206
|
-
if (_deleted) {
|
|
207
|
-
// create the delete statements right away
|
|
208
|
-
const deleteStatement = deleteByIdStatement(instance.id, tableName);
|
|
209
|
-
deleteStatements.add(deleteStatement);
|
|
210
|
-
result.push([item, OpType.DELETE]);
|
|
211
|
-
}
|
|
212
|
-
else {
|
|
213
|
-
// query statements for the saves at first
|
|
214
|
-
const queryStatement = queryByIdStatement(id, tableName);
|
|
215
|
-
queryStatements.add(queryStatement);
|
|
216
|
-
// combination of insert and update items
|
|
217
|
-
itemsToSave.push(instance);
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
// returns the query results for each of the save items
|
|
221
|
-
const queryResponses = await this.db.batchQuery(queryStatements);
|
|
222
|
-
queryResponses.forEach((response, idx) => {
|
|
223
|
-
if (response === undefined) {
|
|
224
|
-
const insertStatement = modelInsertStatement(itemsToSave[idx], tableName);
|
|
225
|
-
saveStatements.add(insertStatement);
|
|
226
|
-
result.push([itemsToSave[idx], OpType.INSERT]);
|
|
227
|
-
}
|
|
228
|
-
else {
|
|
229
|
-
const updateStatement = modelUpdateStatement(itemsToSave[idx], tableName);
|
|
230
|
-
saveStatements.add(updateStatement);
|
|
231
|
-
result.push([itemsToSave[idx], OpType.UPDATE]);
|
|
232
|
-
}
|
|
233
|
-
});
|
|
234
|
-
// perform all of the insert/update/delete operations in a single transaction
|
|
235
|
-
await this.db.batchSave(saveStatements, deleteStatements);
|
|
236
|
-
return result;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { GraphQLScalarType, InternalSchema, PersistentModel, PredicatesGroup, SchemaModel, SortPredicatesGroup } from '@aws-amplify/datastore';
|
|
2
|
-
import { ParameterizedStatement } from './types';
|
|
3
|
-
export declare function getSQLiteType(scalar: keyof Omit<typeof GraphQLScalarType, 'getJSType' | 'getValidationFunction' | 'getSQLiteType'>): 'TEXT' | 'INTEGER' | 'REAL' | 'BLOB';
|
|
4
|
-
export declare function generateSchemaStatements(schema: InternalSchema): string[];
|
|
5
|
-
export declare const implicitAuthFieldsForModel: (model: SchemaModel) => string[];
|
|
6
|
-
export declare function modelCreateTableStatement(model: SchemaModel, userModel?: boolean): string;
|
|
7
|
-
export declare function modelInsertStatement(model: PersistentModel, tableName: string): ParameterizedStatement;
|
|
8
|
-
export declare function modelUpdateStatement(model: PersistentModel, tableName: string): ParameterizedStatement;
|
|
9
|
-
export declare function queryByIdStatement(id: string, tableName: string): ParameterizedStatement;
|
|
10
|
-
declare const comparisonOperatorMap: {
|
|
11
|
-
eq: string;
|
|
12
|
-
ne: string;
|
|
13
|
-
le: string;
|
|
14
|
-
lt: string;
|
|
15
|
-
ge: string;
|
|
16
|
-
gt: string;
|
|
17
|
-
};
|
|
18
|
-
declare const logicalOperatorMap: {
|
|
19
|
-
beginsWith: string;
|
|
20
|
-
contains: string;
|
|
21
|
-
notContains: string;
|
|
22
|
-
between: string;
|
|
23
|
-
};
|
|
24
|
-
declare const arrayOperatorMap: {
|
|
25
|
-
in: string;
|
|
26
|
-
notIn: string;
|
|
27
|
-
};
|
|
28
|
-
export declare const whereConditionFromPredicateObject: ({ field, operator, operand, }: {
|
|
29
|
-
field: string;
|
|
30
|
-
operator: keyof typeof logicalOperatorMap | keyof typeof comparisonOperatorMap | keyof typeof arrayOperatorMap;
|
|
31
|
-
operand: any;
|
|
32
|
-
}) => ParameterizedStatement;
|
|
33
|
-
export declare function whereClauseFromPredicate<T extends PersistentModel>(predicate: PredicatesGroup<T>): ParameterizedStatement;
|
|
34
|
-
export declare function orderByClauseFromSort<T extends PersistentModel>(sortPredicate?: SortPredicatesGroup<T>): string;
|
|
35
|
-
export declare function limitClauseFromPagination(limit: number, page?: number): ParameterizedStatement;
|
|
36
|
-
export declare function queryAllStatement<T extends PersistentModel>(tableName: string, predicate?: PredicatesGroup<T>, sort?: SortPredicatesGroup<T>, limit?: number, page?: number): ParameterizedStatement;
|
|
37
|
-
export declare function queryOneStatement(firstOrLast: any, tableName: string): ParameterizedStatement;
|
|
38
|
-
export declare function deleteByIdStatement(id: string, tableName: string): ParameterizedStatement;
|
|
39
|
-
export declare function deleteByPredicateStatement<T extends PersistentModel>(tableName: string, predicate?: PredicatesGroup<T>): ParameterizedStatement;
|
|
40
|
-
export {};
|