1 /* ownCloud Android client application
2 * Copyright (C) 2012-2013 ownCloud Inc.
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2,
6 * as published by the Free Software Foundation.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 package com
.owncloud
.android
.ui
.activity
;
20 import java
.io
.BufferedReader
;
22 import java
.io
.FileReader
;
23 import java
.io
.IOException
;
24 import java
.util
.ArrayList
;
26 import android
.content
.Intent
;
27 import android
.net
.Uri
;
28 import android
.os
.Bundle
;
29 import android
.view
.View
;
30 import android
.view
.View
.OnClickListener
;
31 import android
.widget
.Button
;
32 import android
.widget
.TextView
;
34 import com
.actionbarsherlock
.app
.ActionBar
;
35 import com
.actionbarsherlock
.app
.SherlockActivity
;
36 import com
.actionbarsherlock
.view
.MenuItem
;
37 import com
.owncloud
.android
.R
;
38 import com
.owncloud
.android
.utils
.DisplayUtils
;
39 import com
.owncloud
.android
.utils
.FileStorageUtils
;
40 import com
.owncloud
.android
.utils
.Log_OC
;
43 public class LogHistoryActivity
extends SherlockActivity
{
45 private static final String MAIL_ATTACHMENT_TYPE
= "text/plain";
47 private static final String TAG
= LogHistoryActivity
.class.getSimpleName();
49 private String mLogPath
= FileStorageUtils
.getLogPath();
50 private File logDIR
= null
;
54 protected void onCreate(Bundle savedInstanceState
) {
55 super.onCreate(savedInstanceState
);
57 setContentView(R
.layout
.log_send_file
);
58 setTitle(getText(R
.string
.actionbar_logger
));
59 ActionBar actionBar
= getSherlock().getActionBar();
60 actionBar
.setIcon(DisplayUtils
.getSeasonalIconId());
61 actionBar
.setDisplayHomeAsUpEnabled(true
);
62 Button deleteHistoryButton
= (Button
) findViewById(R
.id
.deleteLogHistoryButton
);
63 Button sendHistoryButton
= (Button
) findViewById(R
.id
.sendLogHistoryButton
);
65 deleteHistoryButton
.setOnClickListener(new OnClickListener() {
68 public void onClick(View v
) {
75 sendHistoryButton
.setOnClickListener(new OnClickListener() {
78 public void onClick(View v
) {
84 logDIR
= new File(mLogPath
);
87 if(logDIR
!= null
&& logDIR
.isDirectory()) {
94 public boolean onMenuItemSelected(int featureId
, MenuItem item
) {
95 super.onMenuItemSelected(featureId
, item
);
96 switch (item
.getItemId()) {
97 case android
.R
.id
.home
:
108 * Start activity for sending email with logs attached
110 private void sendMail() {
112 String emailAddresses
[] = { getText(R
.string
.mail_logger
).toString() };
114 ArrayList
<Uri
> uris
= new ArrayList
<Uri
>();
116 // Convert from paths to Android friendly Parcelable Uri's
117 for (String file
: Log_OC
.getLogFileNames())
119 if (new File(mLogPath
+ File
.separator
, file
).exists()) {
120 Uri u
= Uri
.parse("file://" + mLogPath
+ File
.separator
+ file
);
125 Intent intent
= new Intent(Intent
.ACTION_SEND_MULTIPLE
);
127 // Explicitly only use Gmail to send
128 intent
.setClassName("com.google.android.gm","com.google.android.gm.ComposeActivityGmail");
129 intent
.putExtra(Intent
.EXTRA_EMAIL
, emailAddresses
);
130 intent
.putExtra(Intent
.EXTRA_SUBJECT
, getText(R
.string
.log_mail_subject
));
131 intent
.setFlags(Intent
.FLAG_ACTIVITY_NEW_TASK
);
132 intent
.setType(MAIL_ATTACHMENT_TYPE
);
133 intent
.putParcelableArrayListExtra(Intent
.EXTRA_STREAM
, uris
);
135 if (intent
.resolveActivity(getPackageManager()) != null
) {
136 startActivity(intent
);
142 * Read and show log file info
144 private void readLogFile() {
146 String
[] logFileName
= Log_OC
.getLogFileNames();
148 //Read text from files
149 StringBuilder text
= new StringBuilder();
155 for (int i
= logFileName
.length
-1; i
>= 0; i
--) {
156 File file
= new File(mLogPath
,logFileName
[i
]);
158 // Check if FileReader is ready
159 if (new FileReader(file
).ready()) {
160 BufferedReader br
= new BufferedReader(new FileReader(file
));
161 while ((line
= br
.readLine()) != null
) {
162 // Append the log info
170 catch (IOException e
) {
171 Log_OC
.d(TAG
, e
.getMessage().toString());
174 // Show in the screen the content of the log
175 TextView logTV
= (TextView
) findViewById(R
.id
.logTV
);