aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/thedevstack/conversationsplus/services/avatar/listener/PublishAvatarMetadataResponseReceived.java
diff options
context:
space:
mode:
authorsteckbrief <steckbrief@chefmail.de>2017-08-06 01:15:13 +0200
committersteckbrief <steckbrief@chefmail.de>2017-08-06 01:15:13 +0200
commit867afe4c5b888ce3f4f9a867906cc8edb86e7aba (patch)
tree82d17b5fcb4471ae884a548fa815a653cb00e000 /src/main/java/de/thedevstack/conversationsplus/services/avatar/listener/PublishAvatarMetadataResponseReceived.java
parent6f588444a953a54543661f7603d45a9093b7196a (diff)
avatar handling refactored
Diffstat (limited to '')
-rw-r--r--src/main/java/de/thedevstack/conversationsplus/services/avatar/listener/PublishAvatarMetadataResponseReceived.java37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/main/java/de/thedevstack/conversationsplus/services/avatar/listener/PublishAvatarMetadataResponseReceived.java b/src/main/java/de/thedevstack/conversationsplus/services/avatar/listener/PublishAvatarMetadataResponseReceived.java
new file mode 100644
index 00000000..79380dbf
--- /dev/null
+++ b/src/main/java/de/thedevstack/conversationsplus/services/avatar/listener/PublishAvatarMetadataResponseReceived.java
@@ -0,0 +1,37 @@
+package de.thedevstack.conversationsplus.services.avatar.listener;
+
+import de.thedevstack.conversationsplus.ConversationsPlusApplication;
+import de.thedevstack.conversationsplus.R;
+import de.thedevstack.conversationsplus.entities.Account;
+import de.thedevstack.conversationsplus.persistance.DatabaseBackend;
+import de.thedevstack.conversationsplus.services.avatar.AvatarCache;
+import de.thedevstack.conversationsplus.ui.UiCallback;
+import de.thedevstack.conversationsplus.xmpp.pep.Avatar;
+import de.thedevstack.conversationsplus.xmpp.stanzas.IqPacket;
+
+/**
+ *
+ */
+public class PublishAvatarMetadataResponseReceived extends AbstractAvatarIqPacketReceived {
+
+ public PublishAvatarMetadataResponseReceived(Avatar avatar, UiCallback uiCallback) {
+ super(avatar, uiCallback);
+ }
+
+ @Override
+ public void onIqPacketReceived(Account account, IqPacket result) {
+ if (result.getType() == IqPacket.TYPE.RESULT) {
+ if (account.setAvatar(avatar.getFilename())) {
+ AvatarCache.clear(account);
+ DatabaseBackend.getInstance(ConversationsPlusApplication.getAppContext()).updateAccount(account);
+ }
+ if (null != callback) {
+ callback.success(avatar);
+ }
+ } else {
+ if (null != callback) {
+ callback.error(R.string.error_publish_avatar_server_reject, avatar);
+ }
+ }
+ }
+}