Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
maurosoria
GitHub Repository: maurosoria/dirsearch
Path: blob/master/lib/report/sqlite_report.py
896 views
1
# -*- coding: utf-8 -*-
2
# This program is free software; you can redistribute it and/or modify
3
# it under the terms of the GNU General Public License as published by
4
# the Free Software Foundation; either version 2 of the License, or
5
# (at your option) any later version.
6
#
7
# This program is distributed in the hope that it will be useful,
8
# but WITHOUT ANY WARRANTY; without even the implied warranty of
9
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
# GNU General Public License for more details.
11
#
12
# You should have received a copy of the GNU General Public License
13
# along with this program; if not, write to the Free Software
14
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
15
# MA 02110-1301, USA.
16
#
17
# Author: Mauro Soria
18
19
import sqlite3
20
21
from lib.report.factory import BaseReport, SQLReportMixin
22
from lib.utils.file import FileUtils
23
24
25
class SQLiteReport(SQLReportMixin, BaseReport):
26
__format__ = "sql"
27
__extension__ = "sqlite"
28
_reuse = False
29
30
def get_create_table_query(self, table):
31
return (f'''CREATE TABLE "{table}" (
32
time DATETIME,
33
url TEXT,
34
status_code INTEGER,
35
content_length INTEGER,
36
content_type TEXT,
37
redirect TEXT
38
);''',)
39
40
def get_insert_table_query(self, table, values):
41
return (f'INSERT INTO "{table}" VALUES (?, ?, ?, ?, ?, ?);', values)
42
43
def connect(self, file):
44
FileUtils.create_dir(FileUtils.parent(file))
45
conn = sqlite3.connect(file, check_same_thread=False)
46
# Check if the file is a proper sqlite database
47
try:
48
conn.cursor().execute("PRAGMA integrity_check")
49
except sqlite3.DatabaseError:
50
raise Exception(f"{file} is not empty or is not a SQLite database")
51
else:
52
return conn
53
54