123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457 |
- package de.tudarmstadt.informatik.hostage.ui;
- import java.util.ArrayList;
- import java.util.HashMap;
- import android.app.Activity;
- import android.app.ActivityManager;
- import android.app.ActivityManager.RunningServiceInfo;
- import android.content.BroadcastReceiver;
- import android.content.ComponentName;
- import android.content.Context;
- import android.content.Intent;
- import android.content.IntentFilter;
- import android.content.ServiceConnection;
- import android.net.ConnectivityManager;
- import android.os.Bundle;
- import android.os.IBinder;
- import android.support.v4.content.LocalBroadcastManager;
- import android.view.GestureDetector;
- import android.view.GestureDetector.SimpleOnGestureListener;
- import android.view.Menu;
- import android.view.MenuItem;
- import android.view.MotionEvent;
- import android.view.View;
- import android.view.View.OnTouchListener;
- import android.view.animation.Animation;
- import android.view.animation.AnimationUtils;
- import android.widget.AdapterView;
- import android.widget.AdapterView.OnItemClickListener;
- import android.widget.CheckBox;
- import android.widget.ImageView;
- import android.widget.ListView;
- import android.widget.TextView;
- import android.widget.Toast;
- import android.widget.ToggleButton;
- import android.widget.ViewAnimator;
- import de.tudarmstadt.informatik.hostage.HoneyListener;
- import de.tudarmstadt.informatik.hostage.HoneyService;
- import de.tudarmstadt.informatik.hostage.HoneyService.LocalBinder;
- import de.tudarmstadt.informatik.hostage.R;
- import de.tudarmstadt.informatik.hostage.commons.HelperUtils;
- import de.tudarmstadt.informatik.hostage.logging.DatabaseHandler;
- public class MainActivity extends Activity {
- public static final String BROADCAST = "de.tudarmstadt.informatik.hostage.BROADCAST";
- public static final int LIGHT_GREY = 0x01;
- public static final int LIGHT_GREEN = 0x02;
- public static final int LIGHT_RED = 0x03;
- public static final int LIGHT_YELLOW = 0x04;
- private HoneyService mService;
- private ViewAnimator viewAnimator;
- private GestureDetector gestureDetector;
- private Animation animFlipInLR;
- private Animation animFlipOutLR;
- private Animation animFlipInRL;
- private Animation animFlipOutRL;
- private ListView listView;
- private ListViewAdapter adapter;
-
- private String protocolClicked;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- initViewAnimator();
- initListView();
- }
- @Override
- public boolean onCreateOptionsMenu(Menu menu) {
- getMenuInflater().inflate(R.menu.main, menu);
- return true;
- }
-
- @Override
- public boolean onOptionsItemSelected(MenuItem item) {
- // Handle item selection
- switch (item.getItemId()) {
- case R.id.action_settings:
- startActivity(new Intent(this, SettingsActivity.class));
- default:
- return super.onOptionsItemSelected(item);
- }
- }
- @Override
- protected void onStart() {
- super.onStart();
- registerReceiver();
- registerNetReceiver();
- if (isServiceRunning()) {
- bindService(getServiceIntent(), mConnection, BIND_AUTO_CREATE);
- }
- }
- @Override
- protected void onStop() {
- if (isServiceRunning()) {
- unbindService(mConnection);
- }
- unregisterReceiver();
- unregisterNetReceiver();
- super.onStop();
- }
- @Override
- protected void onResume() {
- super.onResume();
- updateConnectionInfo();
- }
- public void buttonOnOffClick(View view) {
- if (((ToggleButton) view).isChecked()) {
- if (isParanoid()) {
- protocolClicked = "PANIC";
- } else {
- protocolClicked = "SMB";
- }
- startAndBind();
- } else {
- stopAndUnbind();
- }
- }
- private void startAndBind() {
- startService(getServiceIntent());
- bindService(getServiceIntent(), mConnection, BIND_AUTO_CREATE);
- }
- private void stopAndUnbind() {
- mService.stopListeners();
- unbindService(mConnection);
- stopService(getServiceIntent());
- }
-
- private ServiceConnection mConnection = new ServiceConnection() {
- @Override
- public void onServiceConnected(ComponentName name, IBinder service) {
- mService = ((LocalBinder) service).getService();
- if(protocolClicked != null && protocolClicked.equals("PANIC")){
- mService.startListeners();
- }else{
- mService.toggleListener(protocolClicked);
- }
- protocolClicked = null;
- updateUI();
- }
- @Override
- public void onServiceDisconnected(ComponentName name) {
- mService = null;
- }
- };
-
- private Intent getServiceIntent() {
- return new Intent(this, HoneyService.class);
- }
- private boolean isParanoid() {
- return ((CheckBox) findViewById(R.id.checkBoxParanoid)).isChecked();
- }
- private void initListView() {
- ArrayList<HashMap<String, String>> data = new ArrayList<HashMap<String, String>>();
- for (String protocol : getResources().getStringArray(R.array.protocols)) {
- HashMap<String, String> d = new HashMap<String, String>();
- d.put("light", String.valueOf(R.drawable.light_grey));
- d.put("protocol", protocol);
- d.put("connections", "-");
- data.add(d);
- }
- listView = (ListView) findViewById(R.id.listViewProtocols);
- adapter = new ListViewAdapter(getLayoutInflater(), data);
- listView.setAdapter(adapter);
- listView.setOnTouchListener(new OnTouchListener() {
- @Override
- public boolean onTouch(View v, MotionEvent event) {
- return gestureDetector.onTouchEvent(event);
- }
- });
- listView.setOnItemClickListener(new OnItemClickListener() {
- @Override
- public void onItemClick(AdapterView<?> parent, View view,
- int position, long id) {
- String protocolName = (String) ((HashMap<?, ?>) adapter
- .getItem(position)).get("protocol");
- if (isServiceRunning()) {
- mService.toggleListener(protocolName);
- if(!mService.hasRunningListeners())
- stopAndUnbind();
- }else{
- protocolClicked = protocolName;
- startAndBind();
- }
- }
- });
- }
- private boolean isServiceRunning() {
- ActivityManager manager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
- for (RunningServiceInfo service : manager.getRunningServices(Integer.MAX_VALUE)) {
- if (service.service.getClassName().equals(HoneyService.class.getName())) {
- return true;
- }
- }
- return false;
- }
- private void registerReceiver() {
- LocalBroadcastManager.getInstance(this).registerReceiver(mReceiver,
- new IntentFilter(BROADCAST));
- }
- private void unregisterReceiver() {
- LocalBroadcastManager.getInstance(this).unregisterReceiver(mReceiver);
- }
- private void registerNetReceiver() {
- LocalBroadcastManager.getInstance(this).registerReceiver(netReceiver,
- new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION));
- }
- private void unregisterNetReceiver() {
- LocalBroadcastManager.getInstance(this).unregisterReceiver(netReceiver);
- }
- private BroadcastReceiver mReceiver = new BroadcastReceiver() {
- @Override
- public void onReceive(Context context, Intent intent) {
- updateUI();
- }
- };
- private BroadcastReceiver netReceiver = new BroadcastReceiver() {
- @Override
- public void onReceive(Context context, Intent intent) {
- updateConnectionInfo();
- }
- };
- private void updateUI() {
- boolean activeListeners = false;
- boolean activeHandlers = false;
- if(mService != null){
- for (HoneyListener listener : mService.getListeners()) {
- if (listener.isRunning()) {
- activeListeners = true;
- if (listener.getHandlerCount() == 0) {
- updateProtocolLight(LIGHT_GREEN, listener.getProtocolName());
- } else {
- activeHandlers = true;
- updateProtocolLight(LIGHT_RED, listener.getProtocolName());
- }
- updateProtocolConnections(listener.getHandlerCount(),
- listener.getProtocolName());
- } else {
- updateProtocolLight(LIGHT_GREY, listener.getProtocolName());
- }
- }
- }
- if (activeListeners) {
- if (activeHandlers) {
- updateStatusLight(LIGHT_RED);
- } else {
- updateStatusLight(LIGHT_GREEN);
- }
- ((ToggleButton) findViewById(R.id.toggleButtonOnOff))
- .setChecked(true);
- findViewById(R.id.checkBoxParanoid).setEnabled(false);
- } else {
- updateStatusLight(LIGHT_GREY);
- ((ToggleButton) findViewById(R.id.toggleButtonOnOff))
- .setChecked(false);
- findViewById(R.id.checkBoxParanoid).setEnabled(true);
- }
- }
- private void updateStatusLight(int light) {
- switch (light) {
- case LIGHT_GREY:
- ((ImageView) findViewById(R.id.imageViewLight))
- .setImageResource(R.drawable.light_grey_large);
- break;
- case LIGHT_GREEN:
- ((ImageView) findViewById(R.id.imageViewLight))
- .setImageResource(R.drawable.light_green_large);
- break;
- case LIGHT_RED:
- ((ImageView) findViewById(R.id.imageViewLight))
- .setImageResource(R.drawable.light_red_large);
- break;
- case LIGHT_YELLOW:
- ((ImageView) findViewById(R.id.imageViewLight))
- .setImageResource(R.drawable.light_yellow_large);
- break;
- }
- }
- private void updateProtocolLight(int light, String protocolName) {
- for (int i = 0; i < adapter.getCount(); ++i) {
- HashMap<String, String> d = (HashMap<String, String>) adapter
- .getItem(i);
- if (d.get("protocol").equals(protocolName)) {
- switch (light) {
- case LIGHT_GREY:
- d.put("light", String.valueOf(R.drawable.light_grey));
- d.put("connections", "-");
- break;
- case LIGHT_GREEN:
- d.put("light", String.valueOf(R.drawable.light_green));
- d.put("connections", "0");
- break;
- case LIGHT_RED:
- d.put("light", String.valueOf(R.drawable.light_red));
- break;
- case LIGHT_YELLOW:
- d.put("light", String.valueOf(R.drawable.light_yellow));
- d.put("connections", "0");
- break;
- }
- }
- }
- adapter.notifyDataSetChanged();
- }
- private void updateProtocolConnections(int connections, String protocolName) {
- for (int i = 0; i < adapter.getCount(); ++i) {
- HashMap<String, String> d = ((HashMap<String, String>) adapter
- .getItem(i));
- if (d.get("protocol").equals(protocolName)) {
- d.put("connections", String.valueOf(connections));
- }
- }
- adapter.notifyDataSetChanged();
- }
- private void updateConnectionInfo() {
- TextView ssidView = (TextView) findViewById(R.id.textViewSSIDValue);
- TextView bssidView = (TextView) findViewById(R.id.textViewBSSIDValue);
- TextView internalIPView = (TextView) findViewById(R.id.textViewInternalIPValue);
- TextView externalIPView = (TextView) findViewById(R.id.textViewExternalIPValue);
-
- String ssid = HelperUtils.getSSID(getApplicationContext());
- String bssid = HelperUtils.getBSSID(getApplicationContext());
- String internalIP = HelperUtils.getInternalIP(getApplicationContext());
- String externalIP = HelperUtils.getExternalIP(getApplicationContext());
- if (ssid != null)
- ssidView.setText(ssid);
- else
- ssidView.setText("-");
-
- if (bssid != null)
- bssidView.setText(bssid);
- else
- bssidView.setText("-");
-
- if (internalIP != null)
- internalIPView.setText(internalIP);
- else
- internalIPView.setText("-");
-
- if (externalIP != null)
- externalIPView.setText(externalIP);
- else
- externalIPView.setText("-");
- ssidView.invalidate();
- bssidView.invalidate();
- internalIPView.invalidate();
- }
- /*############# AB HIER KOMMEN HILFSFUNKTIONEN FÜR GESTEN ##################*/
-
- @Override
- public boolean onTouchEvent(MotionEvent event) {
- return gestureDetector.onTouchEvent(event);
- }
-
- private void initViewAnimator() {
- viewAnimator = (ViewAnimator) findViewById(R.id.viewAnimator);
- gestureDetector = new GestureDetector(this, simpleOnGestureListener);
- animFlipInLR = AnimationUtils.loadAnimation(this,
- R.anim.in_left_to_right);
- animFlipOutLR = AnimationUtils.loadAnimation(this,
- R.anim.out_left_to_right);
- animFlipInRL = AnimationUtils.loadAnimation(this,
- R.anim.in_right_to_left);
- animFlipOutRL = AnimationUtils.loadAnimation(this,
- R.anim.out_right_to_left);
- }
-
- private void swipeRightToLeft() {
- if (viewAnimator.getDisplayedChild() == 0) {
- viewAnimator.setInAnimation(animFlipInRL);
- viewAnimator.setOutAnimation(animFlipOutRL);
- viewAnimator.setDisplayedChild(1);
- }
- }
- private void swipeLeftToRight() {
- if (viewAnimator.getDisplayedChild() == 1) {
- viewAnimator.setInAnimation(animFlipInLR);
- viewAnimator.setOutAnimation(animFlipOutLR);
- viewAnimator.setDisplayedChild(0);
- }
- }
- SimpleOnGestureListener simpleOnGestureListener = new SimpleOnGestureListener() {
- @Override
- public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
- float velocityY) {
- float sensitvity = 50;
- if ((e1.getX() - e2.getX()) > sensitvity) {
- swipeRightToLeft();
- } else if ((e2.getX() - e1.getX()) > sensitvity) {
- swipeLeftToRight();
- }
- return true;
- }
- };
-
-
- //TODO NACH TEST ENTFERNEN
- public void showLog(View view){
- startActivity(new Intent(this, ViewLog.class));
- }
- }
|