summaryrefslogtreecommitdiff
path: root/main/src/ui/java/de/blinkt/openvpn/fragments/SendDumpFragment.java
blob: 6d4d2968a339a027361531f54344f4ddeccbc66a (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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
 * Copyright (c) 2012-2016 Arne Schwabe
 * Distributed under the GNU GPL v2 with additional terms. For full terms see the file doc/LICENSE.txt
 */

package de.blinkt.openvpn.fragments;

import java.io.File;
import java.util.ArrayList;
import java.util.Date;

import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager.NameNotFoundException;
import android.net.Uri;
import android.os.Bundle;
import android.util.Pair;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.TextView;

import androidx.fragment.app.Fragment;

import de.blinkt.openvpn.R;
import de.blinkt.openvpn.core.VpnStatus;

public class SendDumpFragment extends Fragment {

    static public Pair<File, Long> getLastestDump(Context c) {
        long newestDumpTime = 0;
        File newestDumpFile = null;

        if (c.getCacheDir() == null)
            return null;

        for (File f : c.getCacheDir().listFiles()) {
            if (!f.getName().endsWith(".dmp"))
                continue;

            if (newestDumpTime < f.lastModified()) {
                newestDumpTime = f.lastModified();
                newestDumpFile = f;
            }
        }
        // Ignore old dumps
        if (System.currentTimeMillis() - 48 * 60 * 1000 > newestDumpTime)
            return null;

        return Pair.create(newestDumpFile, newestDumpTime);
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {

        final View v = inflater.inflate(R.layout.fragment_senddump, container, false);
        v.findViewById(R.id.senddump).setOnClickListener(v1 -> emailMiniDumps());

        new Thread(() -> {
            final Pair<File, Long> ldump = getLastestDump(getActivity());
            if (ldump == null)
                return;
            // Do in background since it does I/O
            getActivity().runOnUiThread(() -> {
                TextView dumpDateText = (TextView) v.findViewById(R.id.dumpdate);
                String datestr = (new Date(ldump.second)).toString();
                long timediff = System.currentTimeMillis() - ldump.second;
                long minutes = timediff / 1000 / 60 % 60;
                long hours = timediff / 1000 / 60 / 60;
                dumpDateText.setText(getString(R.string.lastdumpdate, hours, minutes, datestr));

            });
        }).start();
        return v;
    }

    public void emailMiniDumps() {
        //need to "send multiple" to get more than one attachment
        final Intent emailIntent = new Intent(android.content.Intent.ACTION_SEND_MULTIPLE);
        emailIntent.setType("*/*");
        emailIntent.putExtra(android.content.Intent.EXTRA_EMAIL,
                new String[]{"Arne Schwabe <arne@rfc2549.org>"});

        String version;
        String name = "ics-openvpn";
        try {
            PackageInfo packageinfo = getActivity().getPackageManager().getPackageInfo(getActivity().getPackageName(), 0);
            version = packageinfo.versionName;
            name = packageinfo.applicationInfo.name;
        } catch (NameNotFoundException e) {
            version = "error fetching version";
        }


        emailIntent.putExtra(Intent.EXTRA_SUBJECT, String.format("%s(%s) %s Minidump", name, getActivity().getPackageName(), version));

        emailIntent.putExtra(Intent.EXTRA_TEXT, "Please describe the issue you have experienced");

        ArrayList<Uri> uris = new ArrayList<>();

        Pair<File, Long> ldump = getLastestDump(getActivity());
        if (ldump == null) {
            VpnStatus.logError("No Minidump found!");
            return;
        }

        uris.add(Uri.parse("content://de.blinkt.openvpn.FileProvider/" + ldump.first.getName()));
        uris.add(Uri.parse("content://de.blinkt.openvpn.FileProvider/" + ldump.first.getName() + ".log"));

        emailIntent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
        emailIntent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, uris);
        startActivity(emailIntent);
    }
}