aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/thedevstack/conversationsplus/services/filetransfer/http/delete/DeleteTokenReceived.java
blob: 83a250dedf9d85973c522d9941baea4039af758e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package de.thedevstack.conversationsplus.services.filetransfer.http.delete;

import android.widget.Toast;

import org.json.JSONException;
import org.json.JSONObject;

import java.io.IOException;

import de.thedevstack.android.logcat.Logging;
import de.thedevstack.conversationsplus.R;
import de.thedevstack.conversationsplus.entities.Account;
import de.thedevstack.conversationsplus.enums.FileStatus;
import de.thedevstack.conversationsplus.http.HttpClient;
import de.thedevstack.conversationsplus.utils.MessageUtil;
import de.thedevstack.conversationsplus.utils.ui.ConversationsPlusToast;
import de.thedevstack.conversationsplus.xmpp.OnIqPacketReceived;
import de.thedevstack.conversationsplus.xmpp.exceptions.ServiceUnavailableException;
import de.thedevstack.conversationsplus.xmpp.exceptions.XmppException;
import de.thedevstack.conversationsplus.xmpp.filetransfer.http.delete.DeleteSlotPacketParser;
import de.thedevstack.conversationsplus.xmpp.stanzas.IqPacket;
import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;

/**
 *
 */
public class DeleteTokenReceived implements OnIqPacketReceived {
    private static final String HEADER_NAME_DELETE_TOKEN = "X-FILETRANSFER-HTTP-DELETE-TOKEN";
    private final DeleteRemoteFile remoteFile;

    public DeleteTokenReceived(DeleteRemoteFile remoteFile) {
        this.remoteFile = remoteFile;
    }

    @Override
    public void onIqPacketReceived(Account account, IqPacket packet) {
        try {
            String url = this.remoteFile.getPath();
            String deleteToken = DeleteSlotPacketParser.parseDeleteToken(packet);
            Logging.d("filetransfer.http.delete", "Got delete token '" + deleteToken + "' for remote file '" + remoteFile.getPath() + "'");
            OkHttpClient client = HttpClient.getClient(true);
            Request request = new Request.Builder()
                    .url(url)
                    .addHeader(HEADER_NAME_DELETE_TOKEN, deleteToken)
                    .delete()
                    .build();
            client.newCall(request).enqueue(new Callback() {
                @Override
                public void onFailure(Call call, IOException e) {
                    Logging.e("filetransfer.http.delete", "Error while connecting to '" + call.request().url() + "': " + e.getMessage());
                    MessageUtil.setAndSaveFileStatus(remoteFile.getMessage(), FileStatus.DELETE_FAILED);
                }

                @Override
                public void onResponse(Call call, Response response) throws IOException {
                    if (response.isSuccessful()) {
                        MessageUtil.setAndSaveFileStatus(remoteFile.getMessage(), FileStatus.DELETED);
                        Logging.i("filetransfer.http.delete", "Remote file successfully deleted '" + remoteFile.getPath() + "'");
                    } else {
                        String detailedMessage = response.body().string();
                        FileStatus fileStatus = FileStatus.DELETE_FAILED;
                        switch (response.code()) {
                            case 403:
                            case 500:
                                try {
                                    JSONObject jsonObject = new JSONObject(detailedMessage);
                                    detailedMessage = jsonObject.getString("msg");
                                } catch (JSONException e) {
                                    Logging.e("filetransfer.http.delete", "Failed to get error message from expected json response: " + detailedMessage);
                                }
                                break;
                            case 404:
                                fileStatus = FileStatus.DELETED;
                                Logging.i("filetransfer.http.delete", "Failed to delete file - it was already deleted.");
                                break;
                        }
                        Logging.e("filetransfer.http.delete", "Could not delete remote file '" + remoteFile.getPath() + "'. Response Code: " + response.code() + ", details: " + detailedMessage);
                        MessageUtil.setAndSaveFileStatus(remoteFile.getMessage(), fileStatus);
                    }
                }
            });

        } catch (XmppException e) {
            Logging.e("filetransfer.http.delete", "Error while trying to get the delete token: " + e.getMessage());
            int messageResId = R.string.cplus_remote_file_delete_failed;
            if (e instanceof ServiceUnavailableException) {
                messageResId = R.string.cplus_remote_file_delete_service_unavailable;
            }
            ConversationsPlusToast.makeErrorToast(messageResId, Toast.LENGTH_LONG);
            MessageUtil.setAndSaveFileStatus(remoteFile.getMessage(), FileStatus.DELETE_FAILED);
        }
    }
}