Source code for banffprocessor.metadata.models.uservars

"""Metadata model for user-defined variables."""

import duckdb

from banffprocessor.metadata.models.metadataclass import MetadataClass


[docs] class Uservars(MetadataClass): """User-defined variables metadata class.""" def __init__(self, process: str, specid: str, var: str, value: str, dbconn: duckdb.DuckDBPyConnection = duckdb) -> None: """Validate and create metadata entry, if validation passes.""" self.process = process.casefold() self.specid = specid self.var = var self.value = value # Always store value as a string, leave it up to user to convert # Note that the order of attributes must match the order in the create statement statement = f"INSERT INTO banff.{self.__class__.__name__} VALUES (?, ?, ?, ?)" # noqa: S608 dbconn.execute(statement,[self.process, self.specid, self.var, self.value])
[docs] @classmethod def initialize(cls, dbconn: duckdb.DuckDBPyConnection = duckdb) -> None: """Create duckdb table to store the metadata.""" dbconn.execute(f"DROP TABLE IF EXISTS banff.{cls.__name__}") dbconn.execute("CREATE SCHEMA IF NOT EXISTS banff;") create_statement = f"""CREATE TABLE banff.{cls.__name__} ( process VARCHAR NOT NULL, specid VARCHAR NOT NULL, var VARCHAR NOT NULL, value VARCHAR NOT NULL, PRIMARY KEY(process, specid, var) ) """ dbconn.execute(create_statement)
[docs] @staticmethod def uservars_to_dict(specid: str, process: str, dbconn: duckdb.DuckDBPyConnection) -> dict[str,str]: """Return the user variables for the given specid as a dictionary.""" select_statement = "select var, value from banff.uservars where specid = ? and process = ?" return dict(dbconn.execute(select_statement,[specid, process]).fetchall())
[docs] @staticmethod def get_schema(root_element_name: str = "banffProcessor") -> str: """Return schema (XSD) contents as a string.""" return f"""<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"> <xs:element name="{root_element_name}"> <xs:complexType> <xs:sequence> <xs:element name="uservars" maxOccurs="5000" minOccurs="0"> <xs:complexType> <xs:all> <xs:element name="process"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:minLength value="1"/> <xs:maxLength value="100"/> </xs:restriction> </xs:simpleType> </xs:element> <xs:element name="specid"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:minLength value="1"/> <xs:maxLength value="100"/> </xs:restriction> </xs:simpleType> </xs:element> <xs:element name="var"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:minLength value="1"/> <xs:maxLength value="128"/> </xs:restriction> </xs:simpleType> </xs:element> <xs:element name="value" nillable="true"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:minLength value="1"/> <xs:maxLength value="20000"/> </xs:restriction> </xs:simpleType> </xs:element> </xs:all> </xs:complexType> </xs:element> </xs:sequence> </xs:complexType> </xs:element> </xs:schema>"""