Files
notifications-admin/app/broadcast_areas/repo.py
2020-08-11 12:04:02 +01:00

194 lines
5.7 KiB
Python

import os
import sqlite3
from pathlib import Path
import geojson
class BroadcastAreasRepository(object):
def __init__(self):
self.database = Path(__file__).resolve().parent / 'broadcast-areas.sqlite3'
def conn(self):
return sqlite3.connect(str(self.database))
def delete_db(self):
os.remove(str(self.database))
def create_tables(self):
with self.conn() as conn:
conn.execute("""
CREATE TABLE broadcast_area_libraries (
id TEXT PRIMARY KEY,
name TEXT NOT NULL,
is_group BOOLEAN NOT NULL
)""")
conn.execute("""
CREATE TABLE broadcast_area_library_groups (
id TEXT PRIMARY KEY,
name TEXT NOT NULL,
broadcast_area_library_id TEXT NOT NULL
)""")
conn.execute("""
CREATE TABLE broadcast_areas (
id TEXT PRIMARY KEY,
name TEXT NOT NULL,
broadcast_area_library_id TEXT NOT NULL,
broadcast_area_library_group_id TEXT,
feature_geojson TEXT NOT NULL,
simple_feature_geojson TEXT NOT NULL,
FOREIGN KEY (broadcast_area_library_id)
REFERENCES broadcast_area_libraries(id),
FOREIGN KEY (broadcast_area_library_group_id)
REFERENCES broadcast_area_library_groups(id)
)""")
conn.execute("""
CREATE INDEX broadcast_areas_broadcast_area_library_id
ON broadcast_areas (broadcast_area_library_id);
""")
conn.execute("""
CREATE INDEX broadcast_areas_broadcast_area_library_group_id
ON broadcast_areas (broadcast_area_library_group_id);
""")
def insert_broadcast_area_library(self, id, name, is_group):
q = """
INSERT INTO broadcast_area_libraries (id, name, is_group)
VALUES (?, ?, ?)
"""
with self.conn() as conn:
conn.execute(q, (id, name, is_group))
def insert_broadcast_areas(self, areas):
q = """
INSERT INTO broadcast_areas (
id, name,
broadcast_area_library_id, broadcast_area_library_group_id,
feature_geojson, simple_feature_geojson
)
VALUES (?, ?, ?, ?, ?, ?)
"""
with self.conn() as conn:
for id, name, area_id, group, feature, simple_feature in areas:
conn.execute(q, (
id, name,
area_id, group,
geojson.dumps(feature), geojson.dumps(simple_feature),
))
def query(self, sql, *args):
with self.conn() as conn:
cursor = conn.cursor()
cursor.execute(sql, (*args,))
return cursor.fetchall()
def get_libraries(self):
q = "SELECT id, name, is_group FROM broadcast_area_libraries"
results = self.query(q)
libraries = [(row[0], row[1], row[2]) for row in results]
return sorted(libraries)
def get_library_description(self, library_id):
q = """
WITH
areas AS (SELECT * FROM broadcast_areas
WHERE broadcast_area_library_id = ?),
area_count AS (SELECT COUNT(*) AS c FROM areas),
subset_area_count AS (SELECT c - 4 FROM area_count),
description_area_names AS (SELECT name FROM areas LIMIT 4),
description_areas_joined AS (
SELECT GROUP_CONCAT(name, ", ") FROM description_area_names
)
SELECT
CASE (SELECT * FROM subset_area_count)
WHEN 0 THEN
(SELECT * FROM description_areas_joined)
ELSE
(SELECT * FROM description_areas_joined)
|| ", and "
|| (SELECT * FROM subset_area_count)
|| " more…"
END
"""
description = self.query(q, library_id)[0][0]
return description
def get_areas(self, *area_ids):
with self.conn() as conn:
cursor = conn.cursor()
q = """
SELECT id, name, feature_geojson, simple_feature_geojson
FROM broadcast_areas
WHERE id IN ({})
""".format(("?," * len(*area_ids))[:-1])
cursor.execute(q, *area_ids)
results = cursor.fetchall()
areas = [
(row[0], row[1], row[2], row[3])
for row in results
]
return areas
def get_all_areas_for_library(self, library_id):
q = """
SELECT id, name, feature_geojson, simple_feature_geojson
FROM broadcast_areas
WHERE broadcast_area_library_id = ?
AND broadcast_area_library_group_id IS NULL
"""
results = self.query(q, library_id)
areas = [
(row[0], row[1], row[2], row[3])
for row in results
]
return areas
def get_all_areas_for_group(self, group_id):
q = """
SELECT id, name, feature_geojson, simple_feature_geojson
FROM broadcast_areas
WHERE broadcast_area_library_group_id = ?
"""
results = self.query(q, group_id)
areas = [
(row[0], row[1], row[2], row[3])
for row in results
]
return areas
def get_all_groups_for_library(self, library_id):
q = """
SELECT id, name
FROM broadcast_areas
WHERE broadcast_area_library_group_id = NULL
AND broadcast_area_library_id = ?
"""
results = self.query(q, library_id)
areas = [
(row[0], row[1])
for row in results
]
return areas