nikhil_staging / lilac /data /duckdb_utils.py
nsthorat's picture
Push
c14732f
raw
history blame
No virus
669 Bytes
"""Utils for duckdb."""
import os
import duckdb
from ..config import data_path, env
def duckdb_setup(con: duckdb.DuckDBPyConnection) -> str:
"""Setup DuckDB. This includes setting up the extensions directory and GCS access."""
con.execute(f"""
SET extension_directory='{os.path.join(data_path(), '.duckdb')}';
""")
con.install_extension('httpfs')
con.load_extension('httpfs')
if env('GCS_REGION'):
return f"""
SET s3_region='{env('GCS_REGION')}';
SET s3_access_key_id='{env('GCS_ACCESS_KEY')}';
SET s3_secret_access_key='{env('GCS_SECRET_KEY')}';
SET s3_endpoint='storage.googleapis.com';
"""
return ''