diff options
Diffstat (limited to 'OpenKeychain/src/main/java/org')
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java | 173 | 
1 files changed, 171 insertions, 2 deletions
| diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java index b655a7e55..94d9a60c9 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java @@ -23,8 +23,13 @@ import android.content.Intent;  import android.graphics.Color;  import android.os.Bundle;  import android.support.v4.app.ListFragment; +import android.support.v4.view.MenuItemCompat; +import android.support.v7.widget.SearchView;  import android.util.TypedValue;  import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuInflater; +import android.view.MenuItem;  import android.view.View;  import android.view.ViewGroup;  import android.widget.AdapterView; @@ -32,12 +37,26 @@ import android.widget.AdapterView.OnItemClickListener;  import android.widget.ArrayAdapter;  import android.widget.ImageView;  import android.widget.TextView; +import android.widget.Toast; +import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.operations.results.OperationResult;  import org.sufficientlysecure.keychain.operations.results.OperationResult.LogEntryParcel;  import org.sufficientlysecure.keychain.operations.results.OperationResult.LogLevel;  import org.sufficientlysecure.keychain.operations.results.OperationResult.SubLogEntryParcel; +import org.sufficientlysecure.keychain.provider.KeychainContract; +import org.sufficientlysecure.keychain.provider.KeychainDatabase; +import org.sufficientlysecure.keychain.ui.util.Notify; +import org.sufficientlysecure.keychain.util.ExportHelper; +import org.sufficientlysecure.keychain.util.FileHelper; +import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Preferences; + +import java.io.File; +import java.io.IOException; +import java.io.PrintWriter; +import java.util.Iterator;  public class LogDisplayFragment extends ListFragment implements OnItemClickListener { @@ -46,6 +65,12 @@ public class LogDisplayFragment extends ListFragment implements OnItemClickListe      OperationResult mResult;      public static final String EXTRA_RESULT = "log"; +    @Override +    public void onCreate(Bundle savedInstanceState) { +        super.onCreate(savedInstanceState); + +        setHasOptionsMenu(true); +    }      @Override      public void onActivityCreated(Bundle savedInstanceState) { @@ -70,6 +95,149 @@ public class LogDisplayFragment extends ListFragment implements OnItemClickListe          getListView().setFastScrollEnabled(true);          getListView().setDividerHeight(0); + +    } + +    @Override +    public void onCreateOptionsMenu(final Menu menu, final MenuInflater inflater) { +        Toast.makeText(this.getActivity(),"Options created",Toast.LENGTH_SHORT).show(); +        inflater.inflate(R.menu.log_display, menu); + +        super.onCreateOptionsMenu(menu, inflater); +    } + +    @Override +    public boolean onOptionsItemSelected(MenuItem item) { +        switch(item.getItemId()) { +            case R.id.menu_log_display_export_log: +                exportLog(); +                break; +        } + +        return super.onOptionsItemSelected(item); +    } + +    private void exportLog() { +        Toast.makeText(this.getActivity(),"Exporting log",Toast.LENGTH_LONG).show(); +        showExportLogDialog(new File(Constants.Path.APP_DIR, "export.log")); +    } + +    private void writeToLogFile(final OperationResult.OperationLog operationLog, final File f) { + +        PrintWriter pw = null; +        try { +            pw = new PrintWriter(f); +        } catch(IOException e) { +            e.printStackTrace(); +        } + +        Iterator<LogEntryParcel> logIterator = operationLog.iterator(); + +        while(logIterator.hasNext()) { + +            pw.println(getPrintableLogEntry(logIterator.next())); +        } + +        pw.close(); +    } + +    /** +     * returns an indented String of a LogEntryParcel +     * @param entry log entry whose String representation is to be obtained +     * @return the passed log entry in a readable format +     */ +    private String getPrintableLogEntry(OperationResult.LogEntryParcel entry) { +        String subLogText=null; +        if (entry instanceof SubLogEntryParcel) { +            Log.d("ADI DisplayFragment",entry.toString()); + +            OperationResult result = ((SubLogEntryParcel) entry).getSubResult(); +            LogEntryParcel subEntry = result.getLog().getLast(); +            if (subEntry != null) { +                String subPadding=""; +                for(int i=0;i<entry.mIndent;i++) subPadding+="  ";//2 spaces = 1 Indent + +                subLogText=subPadding+"[SUB]"; +                 +                switch (subEntry.mType.mLevel) { +                    case DEBUG: subLogText+="[DEBUG]"; break; +                    case INFO: subLogText+="[INFO]"; break; +                    case WARN: subLogText+="[WARN]"; break; +                    case ERROR: subLogText+="[WARN]"; break; +                    case START: subLogText+="[START]"; break; +                    case OK: subLogText+="[OK]"; break; +                    case CANCELLED: subLogText+="[CANCELLED]"; break; +                } +                // special case: first parameter may be a quantity +                if (subEntry.mParameters != null && subEntry.mParameters.length > 0 +                        && subEntry.mParameters[0] instanceof Integer) { +                    subLogText+=getResources().getQuantityString(subEntry.mType.getMsgId(), +                            (Integer) subEntry.mParameters[0], +                            subEntry.mParameters); +                } else { +                    subLogText+=getResources().getString(subEntry.mType.getMsgId(), +                            subEntry.mParameters); +                } +            } + +        } else { +            Log.d("ADIExportLogDisplayFragment","NOTSUBLOG:"+entry.toString()); +        } + +        String logText = ""; +        switch (entry.mType.mLevel) { +            case DEBUG: logText="[DEBUG]"; break; +            case INFO: logText="[INFO]"; break; +            case WARN: logText="[WARN]"; break; +            case ERROR: logText="[WARN]"; break; +            case START: logText="[START]"; break; +            case OK: logText="[OK]"; break; +            case CANCELLED: logText="[CANCELLED]"; break; +        } + +        // special case: first parameter may be a quantity +        if (entry.mParameters != null && entry.mParameters.length > 0 +                && entry.mParameters[0] instanceof Integer) { +            logText += getResources().getQuantityString(entry.mType.getMsgId(), +                    (Integer) entry.mParameters[0], +                    entry.mParameters); +        } else { +            logText += getResources().getString(entry.mType.getMsgId(), +                    entry.mParameters); +        } + +        String padding = ""; +        for(int i =0;i<entry.mIndent;i++) { +            padding +="    "; //4 spaces = 1 Indent level +        } +        logText = padding + logText; + +        if(subLogText!=null) //subLog exists +            logText = logText+"\n"+padding+subLogText; + +        return logText; +    } + +    private void showExportLogDialog(final File exportFile) { + +        String title = this.getString(R.string.title_export_log); + +        String message = this.getString(R.string.specify_file_to_export_log_to); + +        FileHelper.saveFile(new FileHelper.FileDialogCallback() { +            @Override +            public void onFileSelected(File file, boolean checked) { +                writeToLogFile(getOperationLog(),file); +            } +        }, this.getActivity().getSupportFragmentManager(), title, message, exportFile, null); +    } + +    private OperationResult.OperationLog getOperationLog(){ +        OperationResult operationResult = this.getActivity().getIntent().getParcelableExtra( +                LogDisplayFragment.EXTRA_RESULT); +        OperationResult.OperationLog operationResultLog = operationResult.getLog(); + +        return operationResultLog;      }      @Override @@ -109,7 +277,7 @@ public class LogDisplayFragment extends ListFragment implements OnItemClickListe                  mSecondImg = secondImg;              }          } - +        //adithyaphilip: Check if convertView.setPadding is redundant          @Override          public View getView(int position, View convertView, ViewGroup parent) {              LogEntryParcel entry = getItem(position); @@ -132,7 +300,7 @@ public class LogDisplayFragment extends ListFragment implements OnItemClickListe              if (entry instanceof SubLogEntryParcel) {                  ih.mSub.setVisibility(View.VISIBLE);                  convertView.setClickable(false); - +                Log.d("ADI DisplayFragment",entry.toString());                  convertView.setPadding((entry.mIndent) * dipFactor, 0, 0, 0);                  OperationResult result = ((SubLogEntryParcel) entry).getSubResult(); @@ -164,6 +332,7 @@ public class LogDisplayFragment extends ListFragment implements OnItemClickListe                  }              } else { +                Log.d("ADI DisplayFragment","NOT:"+entry.toString());                  ih.mSub.setVisibility(View.GONE);                  ih.mSecond.setVisibility(View.GONE);                  convertView.setClickable(true); | 
