From fc52194d3994063a5e8d4a5fc4bf47417e907d50 Mon Sep 17 00:00:00 2001 From: Tom Hacohen Date: Thu, 20 Apr 2017 20:48:12 +0100 Subject: [PATCH] Journalmanager: rename CRUD method to be more consistent. All are now on of: list, delete, create and update. --- .../journalmanager/JournalEntryManager.java | 4 +-- .../journalmanager/JournalManager.java | 8 ++--- .../syncadapter/SyncAdapterService.java | 7 ++-- .../syncadapter/syncadapter/SyncManager.java | 7 ++-- .../ui/CreateCollectionFragment.java | 8 ++--- .../ui/DeleteCollectionFragment.java | 2 +- .../journalmanager/ServiceTest.java | 36 +++++++++---------- 7 files changed, 32 insertions(+), 40 deletions(-) diff --git a/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalEntryManager.java b/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalEntryManager.java index bc5463b8..7465ae63 100644 --- a/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalEntryManager.java +++ b/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalEntryManager.java @@ -35,7 +35,7 @@ public class JournalEntryManager extends BaseManager { this.client = httpClient; } - public List getEntries(Crypto.CryptoManager crypto, String last) throws Exceptions.HttpException, Exceptions.IntegrityException { + public List 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 entries, String last) throws Exceptions.HttpException { + public void create(List entries, String last) throws Exceptions.HttpException { HttpUrl.Builder urlBuilder = this.remote.newBuilder(); if (last != null) { urlBuilder.addQueryParameter("last", last); diff --git a/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalManager.java b/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalManager.java index 41f0c2fb..d681b024 100644 --- a/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalManager.java +++ b/app/src/main/java/com/etesync/syncadapter/journalmanager/JournalManager.java @@ -40,7 +40,7 @@ public class JournalManager extends BaseManager { this.client = httpClient; } - public List getJournals() throws Exceptions.HttpException { + public List 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()); diff --git a/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncAdapterService.java b/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncAdapterService.java index 3760ac42..d9ee2705 100644 --- a/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncAdapterService.java +++ b/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncAdapterService.java @@ -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> 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)); } diff --git a/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncManager.java b/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncManager.java index f7481f0c..45531db8 100644 --- a/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncManager.java +++ b/app/src/main/java/com/etesync/syncadapter/syncadapter/SyncManager.java @@ -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 entries : ListUtils.partition(localEntries, MAX_PUSH)) { - journal.putEntries(entries, remoteCTag); + journal.create(entries, remoteCTag); remoteCTag = entries.get(entries.size() - 1).getUid(); pushed += entries.size(); } diff --git a/app/src/main/java/com/etesync/syncadapter/ui/CreateCollectionFragment.java b/app/src/main/java/com/etesync/syncadapter/ui/CreateCollectionFragment.java index fdaa671e..5adb88aa 100644 --- a/app/src/main/java/com/etesync/syncadapter/ui/CreateCollectionFragment.java +++ b/app/src/main/java/com/etesync/syncadapter/ui/CreateCollectionFragment.java @@ -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 { @@ -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 diff --git a/app/src/main/java/com/etesync/syncadapter/ui/DeleteCollectionFragment.java b/app/src/main/java/com/etesync/syncadapter/ui/DeleteCollectionFragment.java index 88cc560f..cf5bed55 100644 --- a/app/src/main/java/com/etesync/syncadapter/ui/DeleteCollectionFragment.java +++ b/app/src/main/java/com/etesync/syncadapter/ui/DeleteCollectionFragment.java @@ -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); diff --git a/app/src/test/java/com/etesync/syncadapter/journalmanager/ServiceTest.java b/app/src/test/java/com/etesync/syncadapter/journalmanager/ServiceTest.java index 9d9dc2ae..78e114d6 100644 --- a/app/src/test/java/com/etesync/syncadapter/journalmanager/ServiceTest.java +++ b/app/src/test/java/com/etesync/syncadapter/journalmanager/ServiceTest.java @@ -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 journals = journalManager.getJournals(); + List 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 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);