diff options
Diffstat (limited to 'app/src/main')
6 files changed, 166 insertions, 52 deletions
diff --git a/app/src/main/java/org/pacien/tincapp/activities/StartActivity.kt b/app/src/main/java/org/pacien/tincapp/activities/StartActivity.kt index 19d01e6..cecd474 100644 --- a/app/src/main/java/org/pacien/tincapp/activities/StartActivity.kt +++ b/app/src/main/java/org/pacien/tincapp/activities/StartActivity.kt | |||
@@ -2,6 +2,7 @@ package org.pacien.tincapp.activities | |||
2 | 2 | ||
3 | import android.content.Intent | 3 | import android.content.Intent |
4 | import android.os.Bundle | 4 | import android.os.Bundle |
5 | import android.support.v4.widget.SwipeRefreshLayout | ||
5 | import android.view.Menu | 6 | import android.view.Menu |
6 | import android.view.MenuItem | 7 | import android.view.MenuItem |
7 | import android.view.View | 8 | import android.view.View |
@@ -13,16 +14,30 @@ import kotlinx.android.synthetic.main.page_start.* | |||
13 | import org.pacien.tincapp.R | 14 | import org.pacien.tincapp.R |
14 | import org.pacien.tincapp.context.AppPaths | 15 | import org.pacien.tincapp.context.AppPaths |
15 | import org.pacien.tincapp.service.TincVpnService | 16 | import org.pacien.tincapp.service.TincVpnService |
17 | import org.pacien.tincapp.utils.FileObserver | ||
18 | import org.pacien.tincapp.utils.setElements | ||
16 | 19 | ||
17 | /** | 20 | /** |
18 | * @author pacien | 21 | * @author pacien |
19 | */ | 22 | */ |
20 | class StartActivity : BaseActivity(), AdapterView.OnItemClickListener { | 23 | class StartActivity : BaseActivity(), AdapterView.OnItemClickListener, SwipeRefreshLayout.OnRefreshListener { |
24 | |||
25 | private var networkListAdapter: ArrayAdapter<String>? = null | ||
26 | private var confChangeObserver: FileObserver? = null | ||
21 | 27 | ||
22 | override fun onCreate(savedInstanceState: Bundle?) { | 28 | override fun onCreate(savedInstanceState: Bundle?) { |
23 | super.onCreate(savedInstanceState) | 29 | super.onCreate(savedInstanceState) |
30 | |||
31 | networkListAdapter = ArrayAdapter<String>(this, R.layout.fragment_list_item) | ||
32 | confChangeObserver = FileObserver(AppPaths.confDir().absolutePath, FileObserver.CHANGE, { _, _ -> onRefresh() }) | ||
33 | |||
24 | layoutInflater.inflate(R.layout.page_start, main_content) | 34 | layoutInflater.inflate(R.layout.page_start, main_content) |
25 | writeContent() | 35 | network_list_wrapper.setOnRefreshListener(this) |
36 | network_list.addHeaderView(layoutInflater.inflate(R.layout.fragment_network_list_header, network_list, false), null, false) | ||
37 | network_list.addFooterView(View(this), null, false) | ||
38 | network_list.emptyView = network_list_empty | ||
39 | network_list.adapter = networkListAdapter | ||
40 | network_list.onItemClickListener = this | ||
26 | } | 41 | } |
27 | 42 | ||
28 | override fun onCreateOptionsMenu(m: Menu): Boolean { | 43 | override fun onCreateOptionsMenu(m: Menu): Boolean { |
@@ -30,27 +45,44 @@ class StartActivity : BaseActivity(), AdapterView.OnItemClickListener { | |||
30 | return super.onCreateOptionsMenu(m) | 45 | return super.onCreateOptionsMenu(m) |
31 | } | 46 | } |
32 | 47 | ||
33 | override fun onResume() { | 48 | override fun onDestroy() { |
34 | super.onResume() | 49 | confChangeObserver = null |
50 | networkListAdapter = null | ||
51 | super.onDestroy() | ||
52 | } | ||
35 | 53 | ||
36 | if (TincVpnService.isConnected()) startActivity(Intent(this, StatusActivity::class.java) | 54 | override fun onStart() { |
37 | .setFlags(Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK)) | 55 | super.onRestart() |
56 | onRefresh() | ||
57 | confChangeObserver?.startWatching() | ||
38 | } | 58 | } |
39 | 59 | ||
40 | override fun onItemClick(parent: AdapterView<*>?, view: View?, position: Int, id: Long) { | 60 | override fun onStop() { |
41 | PromptActivity.requestVpnPermission((view as TextView).text.toString()) | 61 | super.onStop() |
62 | confChangeObserver?.stopWatching() | ||
42 | } | 63 | } |
43 | 64 | ||
44 | fun openConfigureActivity(@Suppress("UNUSED_PARAMETER") i: MenuItem) { | 65 | override fun onResume() { |
45 | startActivity(Intent(this, ConfigureActivity::class.java)) | 66 | super.onResume() |
67 | if (TincVpnService.isConnected()) openStatusActivity() | ||
46 | } | 68 | } |
47 | 69 | ||
48 | private fun writeContent() { | 70 | override fun onRefresh() { |
49 | network_list.addHeaderView(layoutInflater.inflate(R.layout.fragment_network_list_header, network_list, false), null, false) | 71 | val networks = AppPaths.confDir().list().toList() |
50 | network_list.addFooterView(View(this), null, false) | 72 | runOnUiThread { |
51 | network_list.emptyView = network_list_empty | 73 | networkListAdapter?.setElements(networks) |
52 | network_list.adapter = ArrayAdapter<String>(this, R.layout.fragment_list_item, AppPaths.confDir().list()) | 74 | network_list_wrapper.isRefreshing = false |
53 | network_list.onItemClickListener = this | 75 | } |
54 | } | 76 | } |
55 | 77 | ||
78 | override fun onItemClick(parent: AdapterView<*>?, view: View?, position: Int, id: Long) = | ||
79 | PromptActivity.requestVpnPermission((view as TextView).text.toString()) | ||
80 | |||
81 | fun openConfigureActivity(@Suppress("UNUSED_PARAMETER") i: MenuItem) = | ||
82 | startActivity(Intent(this, ConfigureActivity::class.java)) | ||
83 | |||
84 | fun openStatusActivity() = | ||
85 | startActivity(Intent(this, StatusActivity::class.java) | ||
86 | .setFlags(Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK)) | ||
87 | |||
56 | } | 88 | } |
diff --git a/app/src/main/java/org/pacien/tincapp/activities/StatusActivity.kt b/app/src/main/java/org/pacien/tincapp/activities/StatusActivity.kt index ca572ea..b4ba7dd 100644 --- a/app/src/main/java/org/pacien/tincapp/activities/StatusActivity.kt +++ b/app/src/main/java/org/pacien/tincapp/activities/StatusActivity.kt | |||
@@ -2,6 +2,7 @@ package org.pacien.tincapp.activities | |||
2 | 2 | ||
3 | import android.content.Intent | 3 | import android.content.Intent |
4 | import android.os.Bundle | 4 | import android.os.Bundle |
5 | import android.support.v4.widget.SwipeRefreshLayout | ||
5 | import android.support.v7.app.AlertDialog | 6 | import android.support.v7.app.AlertDialog |
6 | import android.view.Menu | 7 | import android.view.Menu |
7 | import android.view.MenuItem | 8 | import android.view.MenuItem |
@@ -17,16 +18,33 @@ import org.pacien.tincapp.R | |||
17 | import org.pacien.tincapp.commands.Tinc | 18 | import org.pacien.tincapp.commands.Tinc |
18 | import org.pacien.tincapp.service.TincVpnService | 19 | import org.pacien.tincapp.service.TincVpnService |
19 | import org.pacien.tincapp.service.VpnInterfaceConfiguration | 20 | import org.pacien.tincapp.service.VpnInterfaceConfiguration |
21 | import org.pacien.tincapp.utils.setElements | ||
22 | import org.pacien.tincapp.utils.setText | ||
23 | import java.util.* | ||
24 | import kotlin.concurrent.timerTask | ||
20 | 25 | ||
21 | /** | 26 | /** |
22 | * @author pacien | 27 | * @author pacien |
23 | */ | 28 | */ |
24 | class StatusActivity : BaseActivity(), AdapterView.OnItemClickListener { | 29 | class StatusActivity : BaseActivity(), AdapterView.OnItemClickListener, SwipeRefreshLayout.OnRefreshListener { |
30 | |||
31 | private var nodeListAdapter: ArrayAdapter<String>? = null | ||
32 | private var refreshTimer: Timer? = null | ||
33 | private var updateView: Boolean = false | ||
25 | 34 | ||
26 | override fun onCreate(savedInstanceState: Bundle?) { | 35 | override fun onCreate(savedInstanceState: Bundle?) { |
27 | super.onCreate(savedInstanceState) | 36 | super.onCreate(savedInstanceState) |
37 | |||
38 | nodeListAdapter = ArrayAdapter<String>(this, R.layout.fragment_list_item) | ||
39 | refreshTimer = Timer(true) | ||
40 | |||
28 | layoutInflater.inflate(R.layout.page_status, main_content) | 41 | layoutInflater.inflate(R.layout.page_status, main_content) |
29 | writeContent() | 42 | node_list_wrapper.setOnRefreshListener(this) |
43 | node_list.addHeaderView(layoutInflater.inflate(R.layout.fragment_network_status_header, node_list, false), null, false) | ||
44 | node_list.addFooterView(View(this), null, false) | ||
45 | node_list.emptyView = node_list_empty | ||
46 | node_list.onItemClickListener = this | ||
47 | node_list.adapter = nodeListAdapter | ||
30 | } | 48 | } |
31 | 49 | ||
32 | override fun onCreateOptionsMenu(m: Menu): Boolean { | 50 | override fun onCreateOptionsMenu(m: Menu): Boolean { |
@@ -34,55 +52,78 @@ class StatusActivity : BaseActivity(), AdapterView.OnItemClickListener { | |||
34 | return super.onCreateOptionsMenu(m) | 52 | return super.onCreateOptionsMenu(m) |
35 | } | 53 | } |
36 | 54 | ||
37 | override fun onItemClick(parent: AdapterView<*>?, view: View?, position: Int, id: Long) { | 55 | override fun onDestroy() { |
38 | val nodeName = (view as TextView).text.toString() | 56 | super.onDestroy() |
39 | val v = layoutInflater.inflate(R.layout.dialog_text_monopsace, main_content, false) | 57 | refreshTimer?.cancel() |
40 | v.dialog_text_monospace.text = Tinc.info(TincVpnService.getCurrentNetName()!!, nodeName) | 58 | nodeListAdapter = null |
41 | 59 | refreshTimer = null | |
42 | AlertDialog.Builder(this) | ||
43 | .setTitle(R.string.title_node_info) | ||
44 | .setView(v) | ||
45 | .setPositiveButton(R.string.action_close) { _, _ -> /* nop */ } | ||
46 | .show() | ||
47 | } | 60 | } |
48 | 61 | ||
49 | fun stopVpn(@Suppress("UNUSED_PARAMETER") i: MenuItem) { | 62 | override fun onStart() { |
50 | TincVpnService.stopVpn() |