import os, sys, json
import sqlite3
import pprint,time, datetime
def flattenX(candidates):
ret = []
for candidate in candidates:
if 'children' in candidate:
ret.extend(flattenX(candidate['children']))
else:
ret.append(candidate)
return ret
def date_from_webkit(webkit_timestamp):
epoch_start = datetime.datetime(1601,1,1)
delta = datetime.timedelta(microseconds=int(webkit_timestamp))
return (epoch_start + delta) # py3 requires () for print
def listX(data):
candidates = []
for item in data['roots']:
candidates.append(data['roots'][item])
#children = data['roots'][item]['children']
children = flattenX(candidates)
print (len(children))
children = sorted(children, key=lambda x: x['date_added'], reverse=True)
#pprint.pprint(children[:10])
#print(json.dumps(children[:10], indent=4, sort_keys=True))
for i in children[:50]:
#t = time.strftime("%Y-%m-%d %H:%M:%S", time.gmtime(int(i['date_added'])/1000000))
t = date_from_webkit(int(i['date_added']))
print(i['name'], i['url'], t)
def chrome():
paths = [
os.path.expanduser("~/.config/google-chrome/Default/Bookmarks"),
os.path.expanduser(
"~/Library/Application Support/Google/Chrome/Default/Bookmarks"),
os.path.expanduser(
"~\AppData\Local\Google\Chrome\User Data\Default\Bookmarks")
]
path = ""
if "linux" in sys.platform.lower():
path = "~/.config/google-chrome/Default/Bookmarks"
if "darwin" in sys.platform.lower():
path = "~/Library/Application Support/Google/Chrome/Default/Bookmarks"
if "win32" in sys.platform.lower():
path = "~\AppData\Local\Google\Chrome\User Data\Default\Bookmarks"
path = os.path.expanduser(path)
folders = []
urls = []
for f in paths:
if os.path.exists(f):
print(f)
data = json.loads(open(f, encoding='utf-8').read())
#print(json.dumps(data, indent=4, sort_keys=True))
listX(data)
# execute a query on sqlite cursor
def execute_query(cursor, query):
try:
cursor.execute(query)
except Exception as error:
print(str(error) + "
" + query)
# get bookmarks from firefox sqlite database file and print all
def get_bookmarks(cursor):
bookmarks_query = """select url, moz_places.title, rev_host, frecency,
last_visit_date from moz_places join
moz_bookmarks on moz_bookmarks.fk=moz_places.id where visit_count>0
and moz_places.url like 'http%'
order by dateAdded desc;"""
bookmarks_query = """select DISTINCT url, moz_places.title, rev_host, frecency,
last_visit_date, dateAdded from moz_places join
moz_bookmarks on moz_bookmarks.fk=moz_places.id
where visit_count>0
order by dateAdded desc limit 50;"""
execute_query(cursor, bookmarks_query)
for row in cursor:
[link, title, rev_host, frecency, last_visit_date, dateAdded] = row
#link = row[0]
#title = row[1]
t = time.strftime("%Y-%m-%d %H:%M:%S", time.gmtime(dateAdded/1000000))
print(title, link, rev_host, frecency, last_visit_date, t )
def firefox():
path = "~\AppData\Roaming\Mozilla\Firefox\Profiles"
bookmarks_path = os.path.expanduser(path)
# get firefox profile
profiles = []
for i in os.listdir(bookmarks_path):
sqlite_path = '%s\%s\places.sqlite'%(bookmarks_path, i)
if os.path.isfile(sqlite_path):
profiles.append(sqlite_path)
firefox_connection = sqlite3.connect(sqlite_path)
cursor = firefox_connection.cursor()
get_bookmarks(cursor)
cursor.close()
firefox()
print('----------------------------')
chrome()