WIP: updating the automated fingerprinting
This commit is contained in:
parent
d99d1d6a66
commit
d94f5c8659
37
dbfp.py
37
dbfp.py
|
@ -1,6 +1,7 @@
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
|
import os
|
||||||
import argparse
|
import argparse
|
||||||
import time
|
import time
|
||||||
import logging
|
import logging
|
||||||
|
@ -10,6 +11,7 @@ from libs import android
|
||||||
from subprocess import Popen, PIPE, check_call
|
from subprocess import Popen, PIPE, check_call
|
||||||
|
|
||||||
BASE_DIR = "data"
|
BASE_DIR = "data"
|
||||||
|
FP_BASE_DIR = "fingerprints"
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
|
@ -54,16 +56,43 @@ def fingerprintDir():
|
||||||
print "ERROR: adb is not running as root, exec 'adb root'"
|
print "ERROR: adb is not running as root, exec 'adb root'"
|
||||||
return
|
return
|
||||||
|
|
||||||
logging.info("isRoot == {}".format(isRoot))
|
|
||||||
|
|
||||||
if (not mkdir(BASE_DIR)):
|
if (not mkdir(BASE_DIR)):
|
||||||
return
|
return
|
||||||
|
if (not mkdir(FP_BASE_DIR)):
|
||||||
|
return
|
||||||
|
|
||||||
dir_names = ap.getAppsDir()
|
dir_names = ap.getAppsDir()
|
||||||
for dir_name in dir_names:
|
for dir_name in dir_names:
|
||||||
ap.pullApp(BASE_DIR, dir_name)
|
ap.pullApp(BASE_DIR, dir_name)
|
||||||
# logging.info("DIR:: {}".format(dir_names[0]))
|
__createFingerprint(dir_name)
|
||||||
# ap.pullApp(dir_names[0])
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def __createFingerprint(dir_name):
|
||||||
|
try:
|
||||||
|
cdir = dir_name + os.path.sep + "databases"
|
||||||
|
files = os.listdir(cdir)
|
||||||
|
except:
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
db = fingerprint.DBSchema()
|
||||||
|
for filein in files:
|
||||||
|
count = 0
|
||||||
|
retVal = db.scanDBFile(filein)
|
||||||
|
if (retVal > 0):
|
||||||
|
cdir = FP_BASE_DIR + os.path.sep + dir_name
|
||||||
|
if (not mkdir(cdir)):
|
||||||
|
break
|
||||||
|
fname = dir_name + "_" + str(count) + ".json"
|
||||||
|
fh = open(fname, "w")
|
||||||
|
db.writeFingerprint(fh)
|
||||||
|
fh.close()
|
||||||
|
count = count + 1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def mkdir(fdir):
|
def mkdir(fdir):
|
||||||
retval = False
|
retval = False
|
||||||
|
|
|
@ -35,6 +35,7 @@ class DBSchema:
|
||||||
scanner_ver = "0.90"
|
scanner_ver = "0.90"
|
||||||
format_ver = "0.90"
|
format_ver = "0.90"
|
||||||
|
|
||||||
|
#
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.conn = None
|
self.conn = None
|
||||||
self.cur = None
|
self.cur = None
|
||||||
|
@ -48,7 +49,7 @@ class DBSchema:
|
||||||
# self.jsonData = None
|
# self.jsonData = None
|
||||||
return
|
return
|
||||||
|
|
||||||
|
#
|
||||||
def scanDBFile(self, filein):
|
def scanDBFile(self, filein):
|
||||||
# try to open sqlite file
|
# try to open sqlite file
|
||||||
try:
|
try:
|
||||||
|
|
Loading…
Reference in New Issue