mirror of
https://code.briarproject.org/briar/briar.git
synced 2026-02-17 05:09:53 +01:00
Remove BlogPersistentData
This commit is contained in:
@@ -5,7 +5,6 @@ import org.briarproject.CoreModule;
|
|||||||
import org.briarproject.android.api.AndroidExecutor;
|
import org.briarproject.android.api.AndroidExecutor;
|
||||||
import org.briarproject.android.api.AndroidNotificationManager;
|
import org.briarproject.android.api.AndroidNotificationManager;
|
||||||
import org.briarproject.android.api.ReferenceManager;
|
import org.briarproject.android.api.ReferenceManager;
|
||||||
import org.briarproject.android.blogs.BlogPersistentData;
|
|
||||||
import org.briarproject.android.forum.ForumPersistentData;
|
import org.briarproject.android.forum.ForumPersistentData;
|
||||||
import org.briarproject.android.report.BriarReportSender;
|
import org.briarproject.android.report.BriarReportSender;
|
||||||
import org.briarproject.api.blogs.BlogManager;
|
import org.briarproject.api.blogs.BlogManager;
|
||||||
@@ -91,8 +90,6 @@ public interface AndroidComponent extends CoreEagerSingletons {
|
|||||||
|
|
||||||
PrivateMessageFactory privateMessageFactory();
|
PrivateMessageFactory privateMessageFactory();
|
||||||
|
|
||||||
TransportPropertyManager transportPropertyManager();
|
|
||||||
|
|
||||||
ForumManager forumManager();
|
ForumManager forumManager();
|
||||||
|
|
||||||
ForumSharingManager forumSharingManager();
|
ForumSharingManager forumSharingManager();
|
||||||
@@ -119,8 +116,6 @@ public interface AndroidComponent extends CoreEagerSingletons {
|
|||||||
|
|
||||||
ForumPersistentData forumPersistentData();
|
ForumPersistentData forumPersistentData();
|
||||||
|
|
||||||
BlogPersistentData blogPersistentData();
|
|
||||||
|
|
||||||
@IoExecutor
|
@IoExecutor
|
||||||
Executor ioExecutor();
|
Executor ioExecutor();
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import android.app.Application;
|
|||||||
|
|
||||||
import org.briarproject.android.api.AndroidNotificationManager;
|
import org.briarproject.android.api.AndroidNotificationManager;
|
||||||
import org.briarproject.android.api.ReferenceManager;
|
import org.briarproject.android.api.ReferenceManager;
|
||||||
import org.briarproject.android.blogs.BlogPersistentData;
|
|
||||||
import org.briarproject.android.forum.ForumPersistentData;
|
import org.briarproject.android.forum.ForumPersistentData;
|
||||||
import org.briarproject.api.crypto.CryptoComponent;
|
import org.briarproject.api.crypto.CryptoComponent;
|
||||||
import org.briarproject.api.crypto.PublicKey;
|
import org.briarproject.api.crypto.PublicKey;
|
||||||
@@ -65,13 +64,13 @@ public class AppModule {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
public UiCallback provideUICallback() {
|
UiCallback provideUICallback() {
|
||||||
return uiCallback;
|
return uiCallback;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
@Singleton
|
@Singleton
|
||||||
public DatabaseConfig provideDatabaseConfig(Application app) {
|
DatabaseConfig provideDatabaseConfig(Application app) {
|
||||||
final File dir = app.getApplicationContext().getDir("db", MODE_PRIVATE);
|
final File dir = app.getApplicationContext().getDir("db", MODE_PRIVATE);
|
||||||
return new DatabaseConfig() {
|
return new DatabaseConfig() {
|
||||||
|
|
||||||
@@ -103,7 +102,7 @@ public class AppModule {
|
|||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
@Singleton
|
@Singleton
|
||||||
public DevConfig provideDevConfig(final CryptoComponent crypto) {
|
DevConfig provideDevConfig(final CryptoComponent crypto) {
|
||||||
return new DevConfig() {
|
return new DevConfig() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -144,10 +143,4 @@ public class AppModule {
|
|||||||
ForumPersistentData provideForumPersistence() {
|
ForumPersistentData provideForumPersistence() {
|
||||||
return new ForumPersistentData();
|
return new ForumPersistentData();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Provides
|
|
||||||
@Singleton
|
|
||||||
BlogPersistentData provideBlogPersistence() {
|
|
||||||
return new BlogPersistentData();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package org.briarproject.android.blogs;
|
|||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
|
|
||||||
import org.briarproject.android.controller.ActivityLifecycleController;
|
import org.briarproject.android.controller.ActivityLifecycleController;
|
||||||
import org.briarproject.android.controller.handler.UiResultHandler;
|
import org.briarproject.android.controller.handler.ResultHandler;
|
||||||
import org.briarproject.api.sync.GroupId;
|
import org.briarproject.api.sync.GroupId;
|
||||||
import org.briarproject.api.sync.MessageId;
|
import org.briarproject.api.sync.MessageId;
|
||||||
|
|
||||||
@@ -12,7 +12,7 @@ import java.util.TreeSet;
|
|||||||
public interface BlogController extends ActivityLifecycleController {
|
public interface BlogController extends ActivityLifecycleController {
|
||||||
|
|
||||||
void loadBlog(final GroupId groupId, final boolean reload,
|
void loadBlog(final GroupId groupId, final boolean reload,
|
||||||
final UiResultHandler<Boolean> resultHandler);
|
final ResultHandler<Boolean> resultHandler);
|
||||||
|
|
||||||
TreeSet<BlogPostItem> getBlogPosts();
|
TreeSet<BlogPostItem> getBlogPosts();
|
||||||
|
|
||||||
@@ -22,7 +22,7 @@ public interface BlogController extends ActivityLifecycleController {
|
|||||||
@Nullable
|
@Nullable
|
||||||
MessageId getBlogPostId(int position);
|
MessageId getBlogPostId(int position);
|
||||||
|
|
||||||
void deleteBlog(final UiResultHandler<Boolean> resultHandler);
|
void deleteBlog(final ResultHandler<Boolean> resultHandler);
|
||||||
|
|
||||||
interface BlogPostListener {
|
interface BlogPostListener {
|
||||||
void onBlogPostAdded(final BlogPostItem post, final boolean local);
|
void onBlogPostAdded(final BlogPostItem post, final boolean local);
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import android.app.Activity;
|
|||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
|
|
||||||
import org.briarproject.android.controller.DbControllerImpl;
|
import org.briarproject.android.controller.DbControllerImpl;
|
||||||
import org.briarproject.android.controller.handler.UiResultHandler;
|
import org.briarproject.android.controller.handler.ResultHandler;
|
||||||
import org.briarproject.api.blogs.Blog;
|
import org.briarproject.api.blogs.Blog;
|
||||||
import org.briarproject.api.blogs.BlogManager;
|
import org.briarproject.api.blogs.BlogManager;
|
||||||
import org.briarproject.api.blogs.BlogPostHeader;
|
import org.briarproject.api.blogs.BlogPostHeader;
|
||||||
@@ -39,10 +39,10 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
protected volatile BlogManager blogManager;
|
protected volatile BlogManager blogManager;
|
||||||
@Inject
|
@Inject
|
||||||
protected volatile EventBus eventBus;
|
protected volatile EventBus eventBus;
|
||||||
@Inject
|
|
||||||
protected BlogPersistentData data;
|
|
||||||
|
|
||||||
private volatile BlogPostListener listener;
|
private volatile BlogPostListener listener;
|
||||||
|
private volatile GroupId groupId = null;
|
||||||
|
private volatile TreeSet<BlogPostItem> posts = null;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
BlogControllerImpl() {
|
BlogControllerImpl() {
|
||||||
@@ -71,22 +71,23 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onActivityDestroy() {
|
public void onActivityDestroy() {
|
||||||
if (activity.isFinishing()) {
|
|
||||||
data.clearAll();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void eventOccurred(Event e) {
|
public void eventOccurred(Event e) {
|
||||||
if (e instanceof BlogPostAddedEvent) {
|
if (e instanceof BlogPostAddedEvent) {
|
||||||
final BlogPostAddedEvent m = (BlogPostAddedEvent) e;
|
final BlogPostAddedEvent m = (BlogPostAddedEvent) e;
|
||||||
if (m.getGroupId().equals(data.getGroupId())) {
|
if (m.getGroupId().equals(groupId)) {
|
||||||
LOG.info("New blog post added");
|
LOG.info("New blog post added");
|
||||||
|
if (posts == null) {
|
||||||
|
LOG.info("Posts have not loaded, yet");
|
||||||
|
return;
|
||||||
|
}
|
||||||
final BlogPostHeader header = m.getHeader();
|
final BlogPostHeader header = m.getHeader();
|
||||||
try {
|
try {
|
||||||
final byte[] body = blogManager.getPostBody(header.getId());
|
final byte[] body = blogManager.getPostBody(header.getId());
|
||||||
final BlogPostItem post = new BlogPostItem(header, body);
|
final BlogPostItem post = new BlogPostItem(header, body);
|
||||||
data.addPost(post);
|
posts.add(post);
|
||||||
listener.onBlogPostAdded(post, m.isLocal());
|
listener.onBlogPostAdded(post, m.isLocal());
|
||||||
} catch (DbException ex) {
|
} catch (DbException ex) {
|
||||||
if (LOG.isLoggable(WARNING))
|
if (LOG.isLoggable(WARNING))
|
||||||
@@ -95,7 +96,7 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
}
|
}
|
||||||
} else if (e instanceof GroupRemovedEvent) {
|
} else if (e instanceof GroupRemovedEvent) {
|
||||||
GroupRemovedEvent s = (GroupRemovedEvent) e;
|
GroupRemovedEvent s = (GroupRemovedEvent) e;
|
||||||
if (s.getGroup().getId().equals(data.getGroupId())) {
|
if (s.getGroup().getId().equals(groupId)) {
|
||||||
LOG.info("Blog removed");
|
LOG.info("Blog removed");
|
||||||
activity.runOnUiThread(new Runnable() {
|
activity.runOnUiThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
@@ -108,27 +109,27 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void loadBlog(final GroupId groupId, final boolean reload,
|
public void loadBlog(final GroupId g, final boolean reload,
|
||||||
final UiResultHandler<Boolean> resultHandler) {
|
final ResultHandler<Boolean> resultHandler) {
|
||||||
|
|
||||||
LOG.info("Loading blog...");
|
LOG.info("Loading blog...");
|
||||||
runOnDbThread(new Runnable() {
|
runOnDbThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
if (reload || data.getGroupId() == null ||
|
if (reload || posts == null) {
|
||||||
!data.getGroupId().equals(groupId)) {
|
groupId = g;
|
||||||
data.setGroupId(groupId);
|
posts = new TreeSet<>();
|
||||||
// load blog posts
|
// load blog posts
|
||||||
long now = System.currentTimeMillis();
|
long now = System.currentTimeMillis();
|
||||||
Collection<BlogPostItem> posts = new ArrayList<>();
|
Collection<BlogPostItem> newPosts = new ArrayList<>();
|
||||||
Collection<BlogPostHeader> header =
|
Collection<BlogPostHeader> header =
|
||||||
blogManager.getPostHeaders(groupId);
|
blogManager.getPostHeaders(g);
|
||||||
for (BlogPostHeader h : header) {
|
for (BlogPostHeader h : header) {
|
||||||
byte[] body = blogManager.getPostBody(h.getId());
|
byte[] body = blogManager.getPostBody(h.getId());
|
||||||
posts.add(new BlogPostItem(h, body));
|
newPosts.add(new BlogPostItem(h, body));
|
||||||
}
|
}
|
||||||
data.setPosts(posts);
|
posts.addAll(newPosts);
|
||||||
long duration = System.currentTimeMillis() - now;
|
long duration = System.currentTimeMillis() - now;
|
||||||
if (LOG.isLoggable(INFO))
|
if (LOG.isLoggable(INFO))
|
||||||
LOG.info("Post header load took " + duration +
|
LOG.info("Post header load took " + duration +
|
||||||
@@ -145,14 +146,16 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@Nullable
|
||||||
public TreeSet<BlogPostItem> getBlogPosts() {
|
public TreeSet<BlogPostItem> getBlogPosts() {
|
||||||
return data.getBlogPosts();
|
return posts;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Nullable
|
@Nullable
|
||||||
public BlogPostItem getBlogPost(MessageId id) {
|
public BlogPostItem getBlogPost(MessageId id) {
|
||||||
for (BlogPostItem item : getBlogPosts()) {
|
if (posts == null) return null;
|
||||||
|
for (BlogPostItem item : posts) {
|
||||||
if (item.getId().equals(id)) return item;
|
if (item.getId().equals(id)) return item;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
@@ -161,8 +164,9 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
@Override
|
@Override
|
||||||
@Nullable
|
@Nullable
|
||||||
public MessageId getBlogPostId(int position) {
|
public MessageId getBlogPostId(int position) {
|
||||||
|
if (posts == null) return null;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (BlogPostItem post : getBlogPosts()) {
|
for (BlogPostItem post : posts) {
|
||||||
if (i == position) return post.getId();
|
if (i == position) return post.getId();
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
@@ -170,16 +174,16 @@ public class BlogControllerImpl extends DbControllerImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void deleteBlog(final UiResultHandler<Boolean> resultHandler) {
|
public void deleteBlog(final ResultHandler<Boolean> resultHandler) {
|
||||||
runOnDbThread(new Runnable() {
|
runOnDbThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (data.getGroupId() == null) {
|
if (groupId == null) {
|
||||||
resultHandler.onResult(false);
|
resultHandler.onResult(false);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
Blog b = blogManager.getBlog(data.getGroupId());
|
Blog b = blogManager.getBlog(groupId);
|
||||||
blogManager.removeBlog(b);
|
blogManager.removeBlog(b);
|
||||||
resultHandler.onResult(true);
|
resultHandler.onResult(true);
|
||||||
} catch (DbException e) {
|
} catch (DbException e) {
|
||||||
|
|||||||
@@ -1,49 +0,0 @@
|
|||||||
package org.briarproject.android.blogs;
|
|
||||||
|
|
||||||
import org.briarproject.api.sync.GroupId;
|
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.TreeSet;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class is a singleton that defines the data that should persist, i.e.
|
|
||||||
* still be present in memory after activity restarts. This class is not thread
|
|
||||||
* safe.
|
|
||||||
*/
|
|
||||||
public class BlogPersistentData {
|
|
||||||
|
|
||||||
private volatile GroupId groupId;
|
|
||||||
private volatile TreeSet<BlogPostItem> posts = new TreeSet<>();
|
|
||||||
|
|
||||||
public BlogPersistentData() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setGroupId(GroupId groupId) {
|
|
||||||
this.groupId = groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public GroupId getGroupId() {
|
|
||||||
return groupId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPosts(Collection<BlogPostItem> posts) {
|
|
||||||
this.posts.clear();
|
|
||||||
this.posts.addAll(posts);
|
|
||||||
}
|
|
||||||
|
|
||||||
void addPost(BlogPostItem post) {
|
|
||||||
posts.add(post);
|
|
||||||
}
|
|
||||||
|
|
||||||
TreeSet<BlogPostItem> getBlogPosts() {
|
|
||||||
return posts;
|
|
||||||
}
|
|
||||||
|
|
||||||
void clearAll() {
|
|
||||||
groupId = null;
|
|
||||||
posts.clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user