client: Add sync support

When deleting items, this needs to be explicitly activated. For now,
everything will allways be synced as soon as one update with sync set to
true is made. In the future, this will be done in the background.
This commit is contained in:
Elias Projahn 2020-06-03 18:37:20 +02:00
parent 9194b08254
commit 57735337d6
3 changed files with 129 additions and 11 deletions

View file

@ -297,7 +297,12 @@ class MusicusClient {
)); ));
final json = jsonDecode(response.body); final json = jsonDecode(response.body);
return json.map<Person>((j) => Person.fromJson(j)).toList(); return json
.map<Person>((j) => Person.fromJson(j).copyWith(
sync: true,
synced: true,
))
.toList();
} }
/// Get a person by ID. /// Get a person by ID.
@ -307,7 +312,10 @@ class MusicusClient {
)); ));
final json = jsonDecode(response.body); final json = jsonDecode(response.body);
return Person.fromJson(json); return Person.fromJson(json).copyWith(
sync: true,
synced: true,
);
} }
/// Delete a person by ID. /// Delete a person by ID.
@ -358,7 +366,12 @@ class MusicusClient {
)); ));
final json = jsonDecode(response.body); final json = jsonDecode(response.body);
return json.map<Instrument>((j) => Instrument.fromJson(j)).toList(); return json
.map<Instrument>((j) => Instrument.fromJson(j).copyWith(
sync: true,
synced: true,
))
.toList();
} }
/// Get an instrument by ID. /// Get an instrument by ID.
@ -368,7 +381,10 @@ class MusicusClient {
)); ));
final json = jsonDecode(response.body); final json = jsonDecode(response.body);
return Instrument.fromJson(json); return Instrument.fromJson(json).copyWith(
sync: true,
synced: true,
);
} }
/// Create or update an instrument. /// Create or update an instrument.
@ -500,7 +516,12 @@ class MusicusClient {
)); ));
final json = jsonDecode(response.body); final json = jsonDecode(response.body);
return json.map<Ensemble>((j) => Ensemble.fromJson(j)).toList(); return json
.map<Ensemble>((j) => Ensemble.fromJson(j).copyWith(
sync: true,
synced: true,
))
.toList();
} }
/// Get an ensemble by ID. /// Get an ensemble by ID.
@ -510,7 +531,10 @@ class MusicusClient {
)); ));
final json = jsonDecode(response.body); final json = jsonDecode(response.body);
return Ensemble.fromJson(json); return Ensemble.fromJson(json).copyWith(
sync: true,
synced: true,
);
} }
/// Create or update an ensemble. /// Create or update an ensemble.

View file

@ -45,6 +45,50 @@ class MusicusClientDatabase extends _$MusicusClientDatabase {
this.client, this.client,
}) : super.connect(connection); }) : super.connect(connection);
/// Upload all changes to the server.
///
/// If [update] is true, this will also update existing items with new data
/// from the server.
Future<void> sync([bool update = false]) async {
if (update) {
for (final person in await oldSyncPersons().get()) {
await updatePerson(await client.getPerson(person.id));
}
for (final instrument in await oldSyncInstruments().get()) {
await updateInstrument(await client.getInstrument(instrument.id));
}
for (final work in await oldSyncWorks().get()) {
final workInfo = await client.getWork(work.id);
await updateWork(workInfo);
}
for (final ensemble in await oldSyncEnsembles().get()) {
await updateEnsemble(await client.getEnsemble(ensemble.id));
}
for (final recording in await oldSyncRecordings().get()) {
final recordingInfo = await client.getRecording(recording.id);
await updateRecording(recordingInfo);
}
}
for (final person in await newSyncPersons().get()) {
await client.putPerson(person);
}
for (final instrument in await newSyncInstruments().get()) {
await client.putInstrument(instrument);
}
for (final work in await newSyncWorks().get()) {
final workInfo = await getWorkInfo(work);
await client.putWork(workInfo);
}
for (final ensemble in await newSyncEnsembles().get()) {
await client.putEnsemble(ensemble);
}
for (final recording in await newSyncRecordings().get()) {
final recordingInfo = await getRecordingInfo(recording);
await client.putRecording(recordingInfo);
}
}
/// Get all available persons. /// Get all available persons.
/// ///
/// This will return a list of [pageSize] persons. You can get another page /// This will return a list of [pageSize] persons. You can get another page
@ -69,6 +113,10 @@ class MusicusClientDatabase extends _$MusicusClientDatabase {
person, person,
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
); );
if (person.sync) {
await sync();
}
} }
/// Delete the person by [id]. /// Delete the person by [id].
@ -108,6 +156,10 @@ class MusicusClientDatabase extends _$MusicusClientDatabase {
instrument, instrument,
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
); );
if (instrument.sync) {
await sync();
}
} }
/// Delete the instrument by [id]. /// Delete the instrument by [id].
@ -235,6 +287,10 @@ class MusicusClientDatabase extends _$MusicusClientDatabase {
await into(workSections).insert(section); await into(workSections).insert(section);
} }
}); });
if (workInfo.work.sync) {
await sync();
}
} }
/// Delete the work by [id]. /// Delete the work by [id].
@ -276,6 +332,10 @@ class MusicusClientDatabase extends _$MusicusClientDatabase {
ensemble, ensemble,
mode: InsertMode.insertOrReplace, mode: InsertMode.insertOrReplace,
); );
if (ensemble.sync) {
await sync();
}
} }
/// Delete the ensemble by [id]. /// Delete the ensemble by [id].
@ -325,6 +385,10 @@ class MusicusClientDatabase extends _$MusicusClientDatabase {
)); ));
} }
}); });
if (recordingInfo.recording.sync) {
await sync();
}
} }
/// Retreive more information on an already queried recording. /// Retreive more information on an already queried recording.

View file

@ -74,6 +74,12 @@ allPersons:
SELECT * FROM persons ORDER BY last_name, first_name SELECT * FROM persons ORDER BY last_name, first_name
LIMIT :limit OFFSET :offset; LIMIT :limit OFFSET :offset;
newSyncPersons:
SELECT * FROM persons WHERE sync = TRUE AND synced = FALSE;
oldSyncPersons:
SELECT * FROM persons WHERE sync = TRUE AND synced = TRUE;
searchPersons: searchPersons:
SELECT * FROM persons WHERE last_name LIKE :search SELECT * FROM persons WHERE last_name LIKE :search
ORDER BY last_name, first_name LIMIT :limit OFFSET :offset; ORDER BY last_name, first_name LIMIT :limit OFFSET :offset;
@ -84,6 +90,12 @@ SELECT * FROM persons WHERE id = :id LIMIT 1;
allInstruments: allInstruments:
SELECT * FROM instruments ORDER BY name LIMIT :limit OFFSET :offset; SELECT * FROM instruments ORDER BY name LIMIT :limit OFFSET :offset;
newSyncInstruments:
SELECT * FROM instruments WHERE sync = TRUE AND synced = FALSE;
oldSyncInstruments:
SELECT * FROM instruments WHERE sync = TRUE AND synced = TRUE;
searchInstruments: searchInstruments:
SELECT * FROM instruments WHERE name LIKE :search ORDER BY name SELECT * FROM instruments WHERE name LIKE :search ORDER BY name
LIMIT :limit OFFSET :offset; LIMIT :limit OFFSET :offset;
@ -91,6 +103,12 @@ SELECT * FROM instruments WHERE name LIKE :search ORDER BY name
instrumentById: instrumentById:
SELECT * FROM instruments WHERE id = :id LIMIT 1; SELECT * FROM instruments WHERE id = :id LIMIT 1;
newSyncWorks:
SELECT * FROM works WHERE sync = TRUE AND synced = FALSE;
oldSyncWorks:
SELECT * FROM works WHERE sync = TRUE AND synced = TRUE;
workById: workById:
SELECT * FROM works WHERE id = :id LIMIT 1; SELECT * FROM works WHERE id = :id LIMIT 1;
@ -131,6 +149,12 @@ SELECT instruments.* FROM part_instrumentations
allEnsembles: allEnsembles:
SELECT * FROM ensembles ORDER BY name LIMIT :limit OFFSET :offset; SELECT * FROM ensembles ORDER BY name LIMIT :limit OFFSET :offset;
newSyncEnsembles:
SELECT * FROM ensembles WHERE sync = TRUE AND synced = FALSE;
oldSyncEnsembles:
SELECT * FROM ensembles WHERE sync = TRUE AND synced = TRUE;
searchEnsembles: searchEnsembles:
SELECT * FROM ensembles WHERE name LIKE :search ORDER BY name SELECT * FROM ensembles WHERE name LIKE :search ORDER BY name
LIMIT :limit OFFSET :offset; LIMIT :limit OFFSET :offset;
@ -138,6 +162,12 @@ SELECT * FROM ensembles WHERE name LIKE :search ORDER BY name
ensembleById: ensembleById:
SELECT * FROM ensembles WHERE id = :id LIMIT 1; SELECT * FROM ensembles WHERE id = :id LIMIT 1;
newSyncRecordings:
SELECT * FROM recordings WHERE sync = TRUE AND synced = FALSE;
oldSyncRecordings:
SELECT * FROM recordings WHERE sync = TRUE AND synced = TRUE;
recordingById: recordingById:
SELECT * FROM recordings WHERE id = :id; SELECT * FROM recordings WHERE id = :id;