1
0
Fork 0
mirror of https://github.com/M66B/NetGuard.git synced 2025-01-01 12:54:07 +00:00

Persists resolved DNS

This commit is contained in:
M66B 2016-02-03 17:09:12 +01:00
parent f20b586710
commit f8c5a4cf32
2 changed files with 66 additions and 8 deletions

View file

@ -34,7 +34,7 @@ public class DatabaseHelper extends SQLiteOpenHelper {
private static final String TAG = "NetGuard.Database";
private static final String DB_NAME = "Netguard";
private static final int DB_VERSION = 13;
private static final int DB_VERSION = 14;
private static boolean once = true;
private static List<LogChangedListener> logChangedListeners = new ArrayList<>();
@ -116,6 +116,19 @@ public class DatabaseHelper extends SQLiteOpenHelper {
db.execSQL("CREATE UNIQUE INDEX idx_access ON access(uid, daddr, dport)");
}
private void createTableDns(SQLiteDatabase db) {
Log.i(TAG, "Creating dns table");
db.execSQL("CREATE TABLE dns (" +
" ID INTEGER PRIMARY KEY AUTOINCREMENT" +
", time INTEGER NOT NULL" +
", qname TEXT NOT NULL" +
", aname TEXT NOT NULL" +
", resource TEXT NOT NULL" +
", ttl INTEGER NULL" +
");");
db.execSQL("CREATE INDEX idx_dns ON dns(qname, aname, resource)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.i(TAG, DB_NAME + " upgrading from version " + oldVersion + " to " + newVersion);
@ -180,6 +193,10 @@ public class DatabaseHelper extends SQLiteOpenHelper {
db.execSQL("CREATE INDEX idx_log_dname ON log(dname)");
oldVersion = 13;
}
if (oldVersion < 14) {
createTableDns(db);
oldVersion = 14;
}
if (oldVersion == DB_VERSION) {
db.setVersion(oldVersion);
@ -394,6 +411,34 @@ public class DatabaseHelper extends SQLiteOpenHelper {
return db.compileStatement("SELECT COUNT(*) FROM access WHERE block >=0 AND uid =" + uid).simpleQueryForLong();
}
public DatabaseHelper insertDns(ResourceRecord rr) {
synchronized (mContext.getApplicationContext()) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues cv = new ContentValues();
cv.put("time", rr.Time);
cv.put("ttl", rr.TTL);
int rows = db.update("dns", cv, "qname = ? AND aname = ? AND resource = ?",
new String[]{rr.QName, rr.AName});
if (rows == 0) {
cv.put("qname", rr.QName);
cv.put("aname", rr.AName);
cv.put("resource", rr.Resource);
if (db.insert("dns", null, cv) == -1)
Log.e(TAG, "Insert dns failed");
else
Log.i(TAG, "Inserted " + rr);
} else if (rows != 1)
Log.e(TAG, "Update dns failed");
else
Log.i(TAG, "Updated " + rr);
}
return this;
}
public void addLogChangedListener(LogChangedListener listener) {
logChangedListeners.add(listener);

View file

@ -130,6 +130,7 @@ public class SinkholeService extends VpnService implements SharedPreferences.OnS
private static final int MSG_STATS_STOP = 2;
private static final int MSG_STATS_UPDATE = 3;
private static final int MSG_PACKET = 4;
private static final int MSG_RR = 5;
private enum State {none, waiting, enforcing, stats}
@ -207,6 +208,10 @@ public class SinkholeService extends VpnService implements SharedPreferences.OnS
case MSG_PACKET:
log((Packet) msg.obj);
break;
case MSG_RR:
resolved((ResourceRecord) msg.obj);
break;
}
} catch (Throwable ex) {
Log.e(TAG, ex.toString() + "\n" + Log.getStackTraceString(ex));
@ -705,6 +710,17 @@ public class SinkholeService extends VpnService implements SharedPreferences.OnS
dh.close();
}
private void resolved(ResourceRecord rr) {
synchronized (mapRR) {
try {
mapRR.put(InetAddress.getByName(rr.Resource), rr);
new DatabaseHelper(SinkholeService.this).insertDns(rr).close();
} catch (UnknownHostException ex) {
Log.e(TAG, ex.toString() + "\n" + Log.getStackTraceString(ex));
}
}
}
private void set(Intent intent) {
// Get arguments
int uid = intent.getIntExtra(EXTRA_UID, 0);
@ -1045,13 +1061,10 @@ public class SinkholeService extends VpnService implements SharedPreferences.OnS
// Called from native code
private void dnsResolved(ResourceRecord rr) {
synchronized (mapRR) {
try {
mapRR.put(InetAddress.getByName(rr.Resource), rr);
} catch (UnknownHostException ex) {
Log.e(TAG, ex.toString() + "\n" + Log.getStackTraceString(ex));
}
}
Message msg = mServiceHandler.obtainMessage();
msg.obj = rr;
msg.what = MSG_RR;
mServiceHandler.sendMessage(msg);
}
public static ResourceRecord reverseDNS(InetAddress ip) {