Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
C
common-package
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Deploy
Releases
Package Registry
Model registry
Operate
Terraform modules
Analyze
Value stream analytics
Contributor analytics
Repository analytics
Code review analytics
Issue analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
GSHS Utilities
common-package
Merge requests
!29
Develop
Code
Review changes
Check out branch
Download
Patches
Plain diff
Closed
Develop
develop
into
main
Overview
0
Commits
153
Pipelines
0
Changes
1
Closed
Huihui, Jonathan
requested to merge
develop
into
main
1 year ago
Overview
0
Commits
153
Pipelines
0
Changes
1
Expand
0
0
Merge request reports
Viewing commit
8d34fde9
Prev
Next
Show latest version
1 file
+
1
−
1
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
8d34fde9
update rich to version 13.7.1
· 8d34fde9
Tester Jr, Christopher
authored
8 months ago
src/common/mixins/sqlite.py
0 → 100644
+
75
−
0
Options
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
Allow opening with a sqlite3 connection.
"""
import
sqlite3
from
common.env
import
check_environment
as
ce
from
common.logz
import
create_logger
logger
=
create_logger
()
class
SQLiteMixin
:
"""
Serve common connection method for sqlite.
The default `search_path` is not applicable here since SQLite does not use schemas.
"""
DEFAULT_DB
=
ce
(
"
DATABASE_DB_SQLITE
"
,
ce
(
'
DATABASE_DB
'
,
"
:memory:
"
))
def
open
(
self
):
"""
Explicitly open the database connection
:return: True if connection established, else False
"""
db_name
=
self
.
connection_info
.
get
(
"
dbName
"
,
SQLiteMixin
.
DEFAULT_DB
)
self
.
logger
.
debug
(
f
"
Opening Database Connection to
{
db_name
}
"
)
try
:
self
.
connection
=
sqlite3
.
connect
(
db_name
)
self
.
connection
.
row_factory
=
(
sqlite3
.
Row
)
# This enables column access by name
self
.
cursor
=
self
.
connection
.
cursor
()
self
.
logger
.
debug
(
"
Successfully opened connection to database and created cursor
"
)
except
sqlite3
.
OperationalError
as
error
:
self
.
logger
.
error
(
f
"
Database Error:
{
error
}
"
)
return
False
return
True
def
query
(
self
,
query
):
"""
Query the database.
:param query: A valid SQL statement to send to the database.
:return: None if query
'
s cursor does not have a description, otherwise return the results of using `fetchall()`
"""
if
not
self
.
is_open
():
self
.
logger
.
info
(
"
Database not open, opening now.
"
)
self
.
open
()
# Check if it is already open
self
.
logger
.
debug
(
"
Submitting user specified query to database.
"
)
try
:
self
.
cursor
.
execute
(
query
)
if
self
.
cursor
.
description
is
not
None
:
return
[
dict
(
row
)
for
row
in
self
.
cursor
.
fetchall
()]
return
None
except
sqlite3
.
InterfaceError
as
error
:
self
.
logger
.
error
(
f
"
An unexpected InterfaceError occurred:
{
error
}
"
)
except
sqlite3
.
DataError
as
error
:
self
.
logger
.
error
(
f
"
An unexpected DataError occurred:
{
error
}
"
)
except
sqlite3
.
IntegrityError
as
error
:
self
.
logger
.
error
(
f
"
An unexpected IntegrityError occurred:
{
error
}
"
)
except
sqlite3
.
ProgrammingError
as
error
:
self
.
logger
.
error
(
f
"
An unexpected ProgrammingError occurred:
{
error
}
"
)
except
sqlite3
.
NotSupportedError
as
error
:
self
.
logger
.
error
(
f
"
An unexpected NotSupportedError occurred:
{
error
}
"
)
except
sqlite3
.
DatabaseError
as
error
:
self
.
logger
.
error
(
f
"
An unexpected DatabaseError occurred:
{
error
}
"
)
except
Exception
as
error
:
self
.
logger
.
error
(
"
There was an undetermined issue with the query process:
"
+
f
"
{
error
}
"
)
return
None
def
is_open
(
self
):
"""
Check if the database connection is open.
"""
return
self
.
connection
and
self
.
cursor
Loading