package com.owncloud.android.lib.common.utils; import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Calendar; import android.os.Environment; import android.util.Log; public class Log_OC { private static final String SIMPLE_DATE_FORMAT = "yyyy/MM/dd HH:mm:ss"; private static final String LOG_FOLDER_NAME = "log"; private static final long MAX_FILE_SIZE = 1000000; // 1MB private static String mOwncloudDataFolderLog = "owncloud_log"; private static File mLogFile; private static File mFolder; private static BufferedWriter mBuf; private static String[] mLogFileNames = {"currentLog.txt", "olderLog.txt"}; private static boolean isMaxFileSizeReached = false; private static boolean isEnabled = false; public static void setLogDataFolder(String logFolder){ mOwncloudDataFolderLog = logFolder; } public static void i(String TAG, String message){ Log.i(TAG, message); appendLog(TAG+" : "+ message); } public static void d(String TAG, String message){ Log.d(TAG, message); appendLog(TAG + " : " + message); } public static void d(String TAG, String message, Exception e) { Log.d(TAG, message, e); appendLog(TAG + " : " + message + " Exception : "+ e.getStackTrace()); } public static void e(String TAG, String message){ Log.e(TAG, message); appendLog(TAG + " : " + message); } public static void e(String TAG, String message, Throwable e) { Log.e(TAG, message, e); appendLog(TAG+" : " + message +" Exception : " + e.getStackTrace()); } public static void v(String TAG, String message){ Log.v(TAG, message); appendLog(TAG+" : "+ message); } public static void w(String TAG, String message) { Log.w(TAG, message); appendLog(TAG+" : "+ message); } public static void wtf(String TAG, String message) { Log.wtf(TAG,message); appendLog(TAG+" : "+ message); } /** * Start doing logging * @param logPath : path of log file */ public static void startLogging() { String logPath = Environment.getExternalStorageDirectory() + File.separator + mOwncloudDataFolderLog + File.separator + LOG_FOLDER_NAME; mFolder = new File(logPath); mLogFile = new File(mFolder + File.separator + mLogFileNames[0]); boolean isFileCreated = false; if (!mFolder.exists()) { mFolder.mkdirs(); isFileCreated = true; Log.d("LOG_OC", "Log file created"); } try { // Create the current log file if does not exist mLogFile.createNewFile(); mBuf = new BufferedWriter(new FileWriter(mLogFile, true)); isEnabled = true; if (isFileCreated) { appendPhoneInfo(); } } catch (IOException e) { e.printStackTrace(); } finally { if(mBuf != null) { try { mBuf.close(); } catch(IOException e) { e.printStackTrace(); } } } } /** * Delete history logging */ public static void deleteHistoryLogging() { File folderLogs = new File(mFolder + File.separator); if(folderLogs.isDirectory()){ String[] myFiles = folderLogs.list(); for (int i=0; i MAX_FILE_SIZE) { isMaxFileSizeReached = true; } } } public static String[] getLogFileNames() { return mLogFileNames; } }