wpadebug: Report WSC NFC tag read to wpa_supplicant
Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
3b4832fefe
commit
d1f7a9b331
1 changed files with 74 additions and 17 deletions
|
@ -8,12 +8,19 @@
|
||||||
|
|
||||||
package w1.fi.wpadebug;
|
package w1.fi.wpadebug;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
|
import android.app.AlertDialog;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Parcelable;
|
import android.os.Parcelable;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.content.DialogInterface;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
import android.text.method.ScrollingMovementMethod;
|
import android.text.method.ScrollingMovementMethod;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.nfc.NdefMessage;
|
import android.nfc.NdefMessage;
|
||||||
|
@ -31,28 +38,76 @@ public class WpaNfcActivity extends Activity
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private void show_alert(String title, String message)
|
||||||
public void onCreate(Bundle savedInstanceState)
|
|
||||||
{
|
{
|
||||||
Log.d(TAG, "onCreate");
|
AlertDialog.Builder alert = new AlertDialog.Builder(this);
|
||||||
super.onCreate(savedInstanceState);
|
alert.setTitle(title);
|
||||||
|
alert.setMessage(message);
|
||||||
|
alert.setPositiveButton("OK", new DialogInterface.OnClickListener() {
|
||||||
|
public void onClick(DialogInterface dialog, int id)
|
||||||
|
{
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
alert.create().show();
|
||||||
|
}
|
||||||
|
|
||||||
|
private String wpaCmd(String cmd)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
Log.d(TAG, "Executing wpaCmd: " + cmd);
|
||||||
|
Process proc = Runtime.getRuntime().exec(new String[]{"/system/bin/mksh-su", "-c", "wpa_cli " + cmd});
|
||||||
|
BufferedReader reader = new BufferedReader(new InputStreamReader(proc.getInputStream()));
|
||||||
|
StringBuffer output = new StringBuffer();
|
||||||
|
int read;
|
||||||
|
char[] buffer = new char[1024];
|
||||||
|
while ((read = reader.read(buffer)) > 0)
|
||||||
|
output.append(buffer, 0, read);
|
||||||
|
reader.close();
|
||||||
|
proc.waitFor();
|
||||||
|
Log.d(TAG, "External process completed - exitValue " +
|
||||||
|
proc.exitValue());
|
||||||
|
return output.toString();
|
||||||
|
} catch (IOException e) {
|
||||||
|
show_alert("Could not run external program",
|
||||||
|
"Execution of an external program failed. " +
|
||||||
|
"Maybe mksh-su was not installed.");
|
||||||
|
return null;
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean report_tag_read(byte[] payload)
|
||||||
|
{
|
||||||
|
String res = wpaCmd("WPS_NFC_TAG_READ " + byteArrayHex(payload));
|
||||||
|
if (res == null)
|
||||||
|
return false;
|
||||||
|
if (!res.contains("OK")) {
|
||||||
|
Toast.makeText(this, "Failed to report WSC tag read to " +
|
||||||
|
"wpa_supplicant", Toast.LENGTH_LONG).show();
|
||||||
|
} else {
|
||||||
|
Toast.makeText(this, "Reported WSC tag read to wpa_supplicant",
|
||||||
|
Toast.LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
finish();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResume()
|
public void onCreate(Bundle savedInstanceState)
|
||||||
{
|
{
|
||||||
super.onResume();
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
Intent intent = getIntent();
|
Intent intent = getIntent();
|
||||||
String action = intent.getAction();
|
String action = intent.getAction();
|
||||||
Log.d(TAG, "onResume: action=" + action);
|
Log.d(TAG, "onCreate: action=" + action);
|
||||||
|
|
||||||
if (NfcAdapter.ACTION_NDEF_DISCOVERED.equals(action)) {
|
if (NfcAdapter.ACTION_NDEF_DISCOVERED.equals(action)) {
|
||||||
Log.d(TAG, "onResume - NDEF discovered");
|
Log.d(TAG, "NDEF discovered");
|
||||||
Parcelable[] raw = intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES);
|
Parcelable[] raw = intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES);
|
||||||
if (raw != null) {
|
if (raw != null) {
|
||||||
String txt = "NDEF message count: " + raw.length;
|
Log.d(TAG, "NDEF message count: " + raw.length);
|
||||||
Log.d(TAG, txt);
|
|
||||||
NdefMessage[] msgs = new NdefMessage[raw.length];
|
NdefMessage[] msgs = new NdefMessage[raw.length];
|
||||||
for (int i = 0; i < raw.length; i++) {
|
for (int i = 0; i < raw.length; i++) {
|
||||||
msgs[i] = (NdefMessage) raw[i];
|
msgs[i] = (NdefMessage) raw[i];
|
||||||
|
@ -60,15 +115,17 @@ public class WpaNfcActivity extends Activity
|
||||||
Log.d(TAG, "MIME type: " + rec.toMimeType());
|
Log.d(TAG, "MIME type: " + rec.toMimeType());
|
||||||
byte[] a = rec.getPayload();
|
byte[] a = rec.getPayload();
|
||||||
Log.d(TAG, "NDEF record: " + byteArrayHex(a));
|
Log.d(TAG, "NDEF record: " + byteArrayHex(a));
|
||||||
txt += "\nMessage[" + rec.toMimeType() + "]: " +
|
if (rec.getTnf() == NdefRecord.TNF_MIME_MEDIA &&
|
||||||
byteArrayHex(a);
|
rec.toMimeType().equals("application/vnd/wfa.wsc")) {
|
||||||
|
Log.d(TAG, "WSC tag read");
|
||||||
}
|
}
|
||||||
|
|
||||||
TextView textView = new TextView(this);
|
if (!report_tag_read(a))
|
||||||
textView.setText(txt);
|
return;
|
||||||
textView.setMovementMethod(new ScrollingMovementMethod());
|
|
||||||
setContentView(textView);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
finish();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue