1
0
mirror of https://github.com/etesync/android synced 2025-01-11 08:10:58 +00:00

Journalmanager: rename CRUD method to be more consistent.

All are now on of: list, delete, create and update.
This commit is contained in:
Tom Hacohen 2017-04-20 20:48:12 +01:00
parent 87af98f92d
commit fc52194d39
7 changed files with 32 additions and 40 deletions

View File

@ -35,7 +35,7 @@ public class JournalEntryManager extends BaseManager {
this.client = httpClient;
}
public List<Entry> getEntries(Crypto.CryptoManager crypto, String last) throws Exceptions.HttpException, Exceptions.IntegrityException {
public List<Entry> list(Crypto.CryptoManager crypto, String last) throws Exceptions.HttpException, Exceptions.IntegrityException {
Entry previousEntry = null;
HttpUrl.Builder urlBuilder = this.remote.newBuilder();
if (last != null) {
@ -62,7 +62,7 @@ public class JournalEntryManager extends BaseManager {
return ret;
}
public void putEntries(List<Entry> entries, String last) throws Exceptions.HttpException {
public void create(List<Entry> entries, String last) throws Exceptions.HttpException {
HttpUrl.Builder urlBuilder = this.remote.newBuilder();
if (last != null) {
urlBuilder.addQueryParameter("last", last);

View File

@ -40,7 +40,7 @@ public class JournalManager extends BaseManager {
this.client = httpClient;
}
public List<Journal> getJournals() throws Exceptions.HttpException {
public List<Journal> list() throws Exceptions.HttpException {
Request request = new Request.Builder()
.get()
.url(remote)
@ -57,7 +57,7 @@ public class JournalManager extends BaseManager {
return ret;
}
public void deleteJournal(Journal journal) throws Exceptions.HttpException {
public void delete(Journal journal) throws Exceptions.HttpException {
HttpUrl remote = this.remote.resolve(journal.getUid() + "/");
Request request = new Request.Builder()
.delete()
@ -67,7 +67,7 @@ public class JournalManager extends BaseManager {
newCall(request);
}
public void putJournal(Journal journal) throws Exceptions.HttpException {
public void create(Journal journal) throws Exceptions.HttpException {
RequestBody body = RequestBody.create(JSON, journal.toJson());
Request request = new Request.Builder()
@ -78,7 +78,7 @@ public class JournalManager extends BaseManager {
newCall(request);
}
public void updateJournal(Journal journal) throws Exceptions.HttpException {
public void update(Journal journal) throws Exceptions.HttpException {
HttpUrl remote = this.remote.resolve(journal.getUid() + "/");
RequestBody body = RequestBody.create(JSON, journal.toJson());

View File

@ -17,7 +17,6 @@ import android.content.ContentProviderClient;
import android.content.Context;
import android.content.Intent;
import android.content.SyncResult;
import android.database.sqlite.SQLiteDatabase;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.net.wifi.WifiInfo;
@ -48,13 +47,11 @@ import com.etesync.syncadapter.journalmanager.JournalManager;
import com.etesync.syncadapter.model.CollectionInfo;
import com.etesync.syncadapter.model.JournalEntity;
import com.etesync.syncadapter.model.JournalModel;
import com.etesync.syncadapter.model.ServiceDB;
import com.etesync.syncadapter.model.ServiceEntity;
import com.etesync.syncadapter.ui.PermissionsActivity;
import io.requery.Persistable;
import io.requery.sql.EntityDataStore;
import lombok.Cleanup;
import okhttp3.HttpUrl;
import okhttp3.OkHttpClient;
@ -153,7 +150,7 @@ public abstract class SyncAdapterService extends Service {
List<Pair<JournalManager.Journal, CollectionInfo>> journals = new LinkedList<>();
for (JournalManager.Journal journal : journalsManager.getJournals()) {
for (JournalManager.Journal journal : journalsManager.list()) {
Crypto.CryptoManager crypto;
if (journal.getKey() != null) {
crypto = new Crypto.CryptoManager(journal.getVersion(), settings.getKeyPair(), journal.getKey());
@ -176,7 +173,7 @@ public abstract class SyncAdapterService extends Service {
info.uid = JournalManager.Journal.genUid();
Crypto.CryptoManager crypto = new Crypto.CryptoManager(info.version, settings.password(), info.uid);
JournalManager.Journal journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalsManager.putJournal(journal);
journalsManager.create(journal);
journals.add(new Pair<>(journal, info));
}

View File

@ -33,7 +33,6 @@ import com.etesync.syncadapter.model.SyncEntry;
import com.etesync.syncadapter.resource.LocalCollection;
import com.etesync.syncadapter.resource.LocalResource;
import com.etesync.syncadapter.ui.DebugInfoActivity;
import com.etesync.syncadapter.utils.Base64;
import org.apache.commons.collections4.ListUtils;
@ -283,7 +282,7 @@ abstract public class SyncManager {
int count = data.count(EntryEntity.class).where(EntryEntity.JOURNAL.eq(getJournalEntity())).get().value();
if ((remoteCTag != null) && (count == 0)) {
// If we are updating an existing installation with no saved journal, we need to add
remoteEntries = journal.getEntries(crypto, null);
remoteEntries = journal.list(crypto, null);
int i = 0;
for (JournalEntryManager.Entry entry : remoteEntries) {
SyncEntry cEntry = SyncEntry.fromJournalEntry(crypto, entry);
@ -295,7 +294,7 @@ abstract public class SyncManager {
}
}
} else {
remoteEntries = journal.getEntries(crypto, remoteCTag);
remoteEntries = journal.list(crypto, remoteCTag);
}
App.log.info("Fetched " + String.valueOf(remoteEntries.size()) + " entries");
@ -331,7 +330,7 @@ abstract public class SyncManager {
try {
if (!localEntries.isEmpty()) {
for (List<JournalEntryManager.Entry> entries : ListUtils.partition(localEntries, MAX_PUSH)) {
journal.putEntries(entries, remoteCTag);
journal.create(entries, remoteCTag);
remoteCTag = entries.get(entries.size() - 1).getUid();
pushed += entries.size();
}

View File

@ -14,8 +14,6 @@ import android.app.Dialog;
import android.app.ProgressDialog;
import android.content.ContentResolver;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.provider.CalendarContract;
import android.provider.ContactsContract;
@ -36,12 +34,10 @@ import com.etesync.syncadapter.journalmanager.JournalManager;
import com.etesync.syncadapter.model.CollectionInfo;
import com.etesync.syncadapter.model.JournalEntity;
import com.etesync.syncadapter.model.JournalModel;
import com.etesync.syncadapter.model.ServiceDB;
import com.etesync.syncadapter.model.ServiceEntity;
import io.requery.Persistable;
import io.requery.sql.EntityDataStore;
import lombok.Cleanup;
import okhttp3.HttpUrl;
public class CreateCollectionFragment extends DialogFragment implements LoaderManager.LoaderCallbacks<Exception> {
@ -151,11 +147,11 @@ public class CreateCollectionFragment extends DialogFragment implements LoaderMa
info.uid = JournalManager.Journal.genUid();
Crypto.CryptoManager crypto = new Crypto.CryptoManager(info.version, settings.password(), info.uid);
JournalManager.Journal journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalManager.putJournal(journal);
journalManager.create(journal);
} else {
Crypto.CryptoManager crypto = new Crypto.CryptoManager(info.version, settings.password(), info.uid);
JournalManager.Journal journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalManager.updateJournal(journal);
journalManager.update(journal);
}
// 2. add collection to service

View File

@ -122,7 +122,7 @@ public class DeleteCollectionFragment extends DialogFragment implements LoaderMa
JournalManager journalManager = new JournalManager(HttpClient.create(getContext(), account), principal);
Crypto.CryptoManager crypto = new Crypto.CryptoManager(collectionInfo.version, settings.password(), collectionInfo.uid);
journalManager.deleteJournal(new JournalManager.Journal(crypto, collectionInfo.toJson(), collectionInfo.uid));
journalManager.delete(new JournalManager.Journal(crypto, collectionInfo.toJson(), collectionInfo.uid));
JournalEntity journalEntity = JournalEntity.fetch(data, collectionInfo.getServiceEntity(data), collectionInfo.uid);
journalEntity.setDeleted(true);
data.update(journalEntity);

View File

@ -82,18 +82,18 @@ public class ServiceTest {
info.displayName = "Test";
Crypto.CryptoManager crypto = new Crypto.CryptoManager(info.version, Helpers.keyBase64, info.uid);
JournalManager.Journal journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalManager.putJournal(journal);
journalManager.create(journal);
// Try pushing the same journal (uid clash)
try {
caught = null;
journalManager.putJournal(journal);
journalManager.create(journal);
} catch (Exceptions.HttpException e) {
caught = e;
}
assertNotNull(caught);
List<JournalManager.Journal> journals = journalManager.getJournals();
List<JournalManager.Journal> journals = journalManager.list();
assertEquals(journals.size(), 1);
CollectionInfo info2 = CollectionInfo.fromJson(journals.get(0).getContent(crypto));
assertEquals(info2.displayName, info.displayName);
@ -101,17 +101,17 @@ public class ServiceTest {
// Update journal
info.displayName = "Test 2";
journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalManager.updateJournal(journal);
journalManager.update(journal);
journals = journalManager.getJournals();
journals = journalManager.list();
assertEquals(journals.size(), 1);
info2 = CollectionInfo.fromJson(journals.get(0).getContent(crypto));
assertEquals(info2.displayName, info.displayName);
// Delete journal
journalManager.deleteJournal(journal);
journalManager.delete(journal);
journals = journalManager.getJournals();
journals = journalManager.list();
assertEquals(journals.size(), 0);
// Bad HMAC
@ -120,11 +120,11 @@ public class ServiceTest {
info.displayName = "Test 3";
//// We assume this doesn't update the hmac.
journal.setContent(crypto, info.toJson());
journalManager.putJournal(journal);
journalManager.create(journal);
try {
caught = null;
for (JournalManager.Journal journal1 : journalManager.getJournals()) {
for (JournalManager.Journal journal1 : journalManager.list()) {
Crypto.CryptoManager crypto1 = new Crypto.CryptoManager(info.version, Helpers.keyBase64, journal1.getUid());
journal1.verify(crypto1);
}
@ -144,7 +144,7 @@ public class ServiceTest {
info.displayName = "Test";
Crypto.CryptoManager crypto = new Crypto.CryptoManager(info.version, Helpers.keyBase64, info.uid);
JournalManager.Journal journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalManager.putJournal(journal);
journalManager.create(journal);
JournalEntryManager journalEntryManager = new JournalEntryManager(httpClient, remote, info.uid);
JournalEntryManager.Entry previousEntry = null;
@ -154,7 +154,7 @@ public class ServiceTest {
List<JournalEntryManager.Entry> entries = new LinkedList<>();
entries.add(entry);
journalEntryManager.putEntries(entries, null);
journalEntryManager.create(entries, null);
previousEntry = entry;
entries.clear();
@ -165,14 +165,14 @@ public class ServiceTest {
// Pushing a correct entries without the last parameter
try {
caught = null;
journalEntryManager.putEntries(entries, null);
journalEntryManager.create(entries, null);
} catch (Exceptions.HttpException e) {
caught = e;
}
assertNotNull(caught);
// Adding a second entry
journalEntryManager.putEntries(entries, previousEntry.getUid());
journalEntryManager.create(entries, previousEntry.getUid());
previousEntry = entry2;
entries.clear();
@ -180,9 +180,9 @@ public class ServiceTest {
entries.add(entry2);
// Check last works:
entries = journalEntryManager.getEntries(crypto, entry.getUid());
entries = journalEntryManager.list(crypto, entry.getUid());
assertEquals(entries.size(), 1);
entries = journalEntryManager.getEntries(crypto, entry2.getUid());
entries = journalEntryManager.list(crypto, entry2.getUid());
assertEquals(entries.size(), 0);
// Corrupt the journal and verify we catch it
@ -191,11 +191,11 @@ public class ServiceTest {
entry2.update(crypto, "Content", null);
entries.add(entry2);
journalEntryManager.putEntries(entries, previousEntry.getUid());
journalEntryManager.create(entries, previousEntry.getUid());
try {
caught = null;
journalEntryManager.getEntries(crypto, null);
journalEntryManager.list(crypto, null);
} catch (Exceptions.IntegrityException e) {
caught = e;
}
@ -244,7 +244,7 @@ public class ServiceTest {
info.displayName = "Test";
Crypto.CryptoManager crypto = new Crypto.CryptoManager(info.version, Helpers.keyBase64, info.uid);
JournalManager.Journal journal = new JournalManager.Journal(crypto, info.toJson(), info.uid);
journalManager.putJournal(journal);
journalManager.create(journal);
assertEquals(journalManager.listMembers(journal).size(), 0);