Code source de geonature.core.gn_monitoring.models

"""
    Modèles du schéma gn_monitoring
    Correspond a la centralisation des données de base
        relatifs aux protocoles de suivis
"""

from geoalchemy2 import Geometry
from sqlalchemy import ForeignKey
from sqlalchemy.orm import relationship
from sqlalchemy.dialects.postgresql import UUID, JSONB
from sqlalchemy.sql import select, func


from pypnusershub.db.models import User
from ref_geo.models import LAreas
from utils_flask_sqla.serializers import serializable
from utils_flask_sqla_geo.serializers import geoserializable

from pypnnomenclature.models import TNomenclatures
from geonature.core.gn_commons.models import TModules
from geonature.core.gn_meta.models import TDatasets
from geonature.utils.env import DB


[docs] cor_visit_observer = DB.Table( "cor_visit_observer", DB.Column( "id_base_visit", DB.Integer, ForeignKey("gn_monitoring.t_base_visits.id_base_visit"), primary_key=True, ), DB.Column( "id_role", DB.Integer, ForeignKey("utilisateurs.t_roles.id_role"), primary_key=True, ), schema="gn_monitoring", )
[docs] cor_site_module = DB.Table( "cor_site_module", DB.Column( "id_base_site", DB.Integer, ForeignKey("gn_monitoring.t_base_sites.id_base_site"), primary_key=True, ), DB.Column( "id_module", DB.Integer, ForeignKey("gn_commons.t_modules.id_module"), primary_key=True, ), schema="gn_monitoring", )
[docs] cor_site_area = DB.Table( "cor_site_area", DB.Column( "id_base_site", DB.Integer, ForeignKey("gn_monitoring.t_base_sites.id_base_site"), primary_key=True, ), DB.Column("id_area", DB.Integer, ForeignKey(LAreas.id_area), primary_key=True), schema="gn_monitoring", )
[docs] cor_module_type = DB.Table( "cor_module_type", DB.Column( "id_module", DB.Integer, DB.ForeignKey("gn_commons.t_modules.id_module"), primary_key=True, ), DB.Column( "id_type_site", DB.Integer, DB.ForeignKey("gn_monitoring.bib_type_site.id_nomenclature_type_site"), primary_key=True, ), schema="gn_monitoring", )
[docs] cor_site_type = DB.Table( "cor_site_type", DB.Column( "id_base_site", DB.Integer, DB.ForeignKey("gn_monitoring.t_base_sites.id_base_site"), primary_key=True, ), DB.Column( "id_type_site", DB.Integer, DB.ForeignKey("gn_monitoring.bib_type_site.id_nomenclature_type_site"), primary_key=True, ), schema="gn_monitoring", )
@serializable
[docs] class BibTypeSite(DB.Model):
[docs] __tablename__ = "bib_type_site"
[docs] __table_args__ = {"schema": "gn_monitoring"}
[docs] id_nomenclature_type_site = DB.Column( DB.ForeignKey("ref_nomenclatures.t_nomenclatures.id_nomenclature"), nullable=False, primary_key=True, )
[docs] config = DB.Column(JSONB)
[docs] nomenclature = DB.relationship( TNomenclatures, uselist=False, backref=DB.backref("bib_type_site", uselist=False) )
[docs] sites = DB.relationship("TBaseSites", secondary=cor_site_type, lazy="noload")
@serializable
[docs] class TBaseVisits(DB.Model): """ Table de centralisation des visites liées à un site """
[docs] __tablename__ = "t_base_visits"
[docs] __table_args__ = {"schema": "gn_monitoring"}
[docs] id_base_visit = DB.Column(DB.Integer, primary_key=True)
[docs] id_base_site = DB.Column(DB.Integer, ForeignKey("gn_monitoring.t_base_sites.id_base_site"))
[docs] id_digitiser = DB.Column(DB.Integer, ForeignKey("utilisateurs.t_roles.id_role"))
[docs] id_dataset = DB.Column(DB.Integer, ForeignKey("gn_meta.t_datasets.id_dataset"))
# Pour le moment non défini comme une clé étrangère # pour les questions de perfs # a voir en fonction des usage
[docs] id_module = DB.Column(DB.Integer, ForeignKey("gn_commons.t_modules.id_module"))
[docs] visit_date_min = DB.Column(DB.DateTime)
[docs] visit_date_max = DB.Column(DB.DateTime)
[docs] id_nomenclature_tech_collect_campanule = DB.Column(DB.Integer)
[docs] id_nomenclature_grp_typ = DB.Column(DB.Integer)
[docs] comments = DB.Column(DB.Unicode)
[docs] uuid_base_visit = DB.Column(UUID(as_uuid=True), default=select(func.uuid_generate_v4()))
[docs] meta_create_date = DB.Column(DB.DateTime)
[docs] meta_update_date = DB.Column(DB.DateTime)
[docs] digitiser = relationship( User, primaryjoin=(User.id_role == id_digitiser), foreign_keys=[id_digitiser] )
[docs] observers = DB.relationship( User, secondary=cor_visit_observer, primaryjoin=(cor_visit_observer.c.id_base_visit == id_base_visit), secondaryjoin=(cor_visit_observer.c.id_role == User.id_role), foreign_keys=[cor_visit_observer.c.id_base_visit, cor_visit_observer.c.id_role], )
[docs] observers_txt = DB.Column(DB.Unicode)
[docs] dataset = relationship( TDatasets, primaryjoin=(TDatasets.id_dataset == id_dataset), foreign_keys=[id_dataset], )
@serializable @geoserializable(geoCol="geom", idCol="id_base_site")
[docs] class TBaseSites(DB.Model): """ Table centralisant les données élémentaire des sites """
[docs] __tablename__ = "t_base_sites"
[docs] __table_args__ = {"schema": "gn_monitoring"}
[docs] id_base_site = DB.Column(DB.Integer, primary_key=True)
[docs] id_inventor = DB.Column(DB.Integer, ForeignKey("utilisateurs.t_roles.id_role"))
[docs] id_digitiser = DB.Column(DB.Integer, ForeignKey("utilisateurs.t_roles.id_role"))
[docs] base_site_name = DB.Column(DB.Unicode)
[docs] base_site_description = DB.Column(DB.Unicode)
[docs] base_site_code = DB.Column(DB.Unicode)
[docs] first_use_date = DB.Column(DB.DateTime)
[docs] geom = DB.Column(Geometry("GEOMETRY", 4326))
[docs] uuid_base_site = DB.Column(UUID(as_uuid=True), default=select(func.uuid_generate_v4()))
[docs] meta_create_date = DB.Column(DB.DateTime)
[docs] meta_update_date = DB.Column(DB.DateTime)
[docs] altitude_min = DB.Column(DB.Integer)
[docs] altitude_max = DB.Column(DB.Integer)
[docs] digitiser = relationship( User, primaryjoin=(User.id_role == id_digitiser), foreign_keys=[id_digitiser] )
[docs] inventor = relationship( User, primaryjoin=(User.id_role == id_inventor), foreign_keys=[id_inventor] )
[docs] t_base_visits = relationship("TBaseVisits", lazy="select", cascade="all,delete-orphan")
[docs] modules = DB.relationship( "TModules", lazy="select", enable_typechecks=False, secondary=cor_site_module, primaryjoin=(cor_site_module.c.id_base_site == id_base_site), secondaryjoin=(cor_site_module.c.id_module == TModules.id_module), foreign_keys=[cor_site_module.c.id_base_site, cor_site_module.c.id_module], )
@serializable
[docs] class TObservations(DB.Model):
[docs] __tablename__ = "t_observations"
[docs] __table_args__ = {"schema": "gn_monitoring"}
[docs] id_observation = DB.Column(DB.Integer, primary_key=True, nullable=False, unique=True)
[docs] id_base_visit = DB.Column(DB.ForeignKey("gn_monitoring.t_base_visits.id_base_visit"))
[docs] id_digitiser = DB.Column(DB.Integer, DB.ForeignKey("utilisateurs.t_roles.id_role"))
[docs] digitiser = DB.relationship( User, primaryjoin=(User.id_role == id_digitiser), foreign_keys=[id_digitiser] )
[docs] cd_nom = DB.Column(DB.Integer)
[docs] comments = DB.Column(DB.String)
[docs] uuid_observation = DB.Column(UUID(as_uuid=True), default=select(func.uuid_generate_v4()))