Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
maurosoria
GitHub Repository: maurosoria/dirsearch
Path: blob/master/lib/report/postgresql_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 psycopg
20
21
from lib.core.exceptions import InvalidURLException
22
from lib.core.settings import DB_CONNECTION_TIMEOUT
23
from lib.report.factory import BaseReport, SQLReportMixin
24
25
26
class PostgreSQLReport(SQLReportMixin, BaseReport):
27
__format__ = "sql"
28
__extension__ = None
29
_reuse = True
30
31
def is_valid(self, url):
32
return url.startswith(("postgres://", "postgresql://"))
33
34
def connect(self, url):
35
if not self.is_valid(url):
36
raise InvalidURLException("Provided PostgreSQL URL does not start with postgresql://")
37
38
return psycopg.connect(url, connect_timeout=DB_CONNECTION_TIMEOUT)
39
40