From 7a2b9b1880612c78699f03f62697cdab4a7c6747 Mon Sep 17 00:00:00 2001 From: Arne Schwabe Date: Tue, 10 Jul 2012 22:39:06 +0200 Subject: Add ability to export openvpn configuration. (closes issue #52) --- res/menu/configmenu.xml | 11 ++++++++ res/values/strings.xml | 1 + src/de/blinkt/openvpn/ShowConfigFragment.java | 37 +++++++++++++++++++++++++++ src/de/blinkt/openvpn/VPNProfileList.java | 3 ++- 4 files changed, 51 insertions(+), 1 deletion(-) create mode 100644 res/menu/configmenu.xml diff --git a/res/menu/configmenu.xml b/res/menu/configmenu.xml new file mode 100644 index 0000000..1d47e26 --- /dev/null +++ b/res/menu/configmenu.xml @@ -0,0 +1,11 @@ + + + + + + \ No newline at end of file diff --git a/res/values/strings.xml b/res/values/strings.xml index 6cdfcc7..6fa7815 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -232,6 +232,7 @@ Routing Obscure OpenVPN Settings. Normally not needed. Advanced + ICS Openvpn Config \ No newline at end of file diff --git a/src/de/blinkt/openvpn/ShowConfigFragment.java b/src/de/blinkt/openvpn/ShowConfigFragment.java index 13c65df..8c8ab31 100644 --- a/src/de/blinkt/openvpn/ShowConfigFragment.java +++ b/src/de/blinkt/openvpn/ShowConfigFragment.java @@ -1,14 +1,19 @@ package de.blinkt.openvpn; import android.app.Fragment; +import android.content.Intent; import android.os.Bundle; 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.TextView; public class ShowConfigFragment extends Fragment { + private String configtext; public android.view.View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { String profileUUID = getArguments().getString(getActivity().getPackageName() + ".profileUUID"); @@ -19,11 +24,43 @@ public class ShowConfigFragment extends Fragment { int check=vp.checkProfile(); if(check!=R.string.no_error_found) { cv.setText(check); + configtext = getString(check); } else { String cfg=vp.getConfigFile(getActivity().getCacheDir()); + configtext= cfg; cv.setText(cfg); } return v; }; + + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setHasOptionsMenu(true); + } + + @Override + public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { + inflater.inflate(R.menu.configmenu, menu); + } + + private void shareConfig() { + Intent shareIntent = new Intent(Intent.ACTION_SEND); + shareIntent.putExtra(Intent.EXTRA_TEXT, configtext); + shareIntent.putExtra(Intent.EXTRA_SUBJECT, getString(R.string.export_config_title)); + shareIntent.setType("text/plain"); + startActivity(Intent.createChooser(shareIntent, "Export Configfile")); + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + final int itemId = item.getItemId(); + if (itemId == R.id.sendConfig) { + shareConfig(); + return true; + } else { + return super.onOptionsItemSelected(item); + } + } } diff --git a/src/de/blinkt/openvpn/VPNProfileList.java b/src/de/blinkt/openvpn/VPNProfileList.java index beadf53..aee3ce4 100644 --- a/src/de/blinkt/openvpn/VPNProfileList.java +++ b/src/de/blinkt/openvpn/VPNProfileList.java @@ -291,7 +291,8 @@ public class VPNProfileList extends ListFragment { return true; default: return false; - } } + } + } @Override public void onDestroyActionMode(ActionMode mode) { -- cgit v1.2.3