Code source de geonature.core.gn_meta.models.commons

import datetime
from sqlalchemy.orm import relationship
from sqlalchemy import ForeignKey
from sqlalchemy.ext.hybrid import hybrid_property
import marshmallow as ma


from pypnnomenclature.models import TNomenclatures
from pypnusershub.db.models import User, Organisme
from utils_flask_sqla.serializers import serializable

from geonature.utils.env import DB, db

[docs] MIN_LENGTH_UUID_OR_DATE_SEARCH_STRING = 5
[docs] class DateFilterSchema(ma.Schema):
[docs] year = ma.fields.Integer()
[docs] month = ma.fields.Integer()
[docs] day = ma.fields.Integer()
[docs] class MetadataFilterSchema(ma.Schema):
[docs] class Meta:
[docs] unknown = ma.EXCLUDE
[docs] uuid = ma.fields.UUID(allow_none=True)
[docs] name = ma.fields.String()
[docs] date = ma.fields.Nested(DateFilterSchema)
[docs] person = ma.fields.Integer()
[docs] organism = ma.fields.Integer()
[docs] areas = ma.fields.List(ma.fields.Integer())
[docs] search = ma.fields.String()
@ma.post_load(pass_many=False)
[docs] def convert_date(self, data, **kwargs): if "date" in data: date = data["date"] try: data["date"] = datetime.date( year=date["year"], month=date["month"], day=date["day"] ) except TypeError as exc: raise ma.ValidationError(*exc.args, field_name="date") from exc return data
[docs] cor_acquisition_framework_objectif = db.Table( "cor_acquisition_framework_objectif", db.Column( "id_acquisition_framework", db.Integer, ForeignKey("gn_meta.t_acquisition_frameworks.id_acquisition_framework"), primary_key=True, ), db.Column( "id_nomenclature_objectif", db.Integer, ForeignKey(TNomenclatures.id_nomenclature), primary_key=True, ), schema="gn_meta", )
[docs] cor_acquisition_framework_voletsinp = db.Table( "cor_acquisition_framework_voletsinp", db.Column( "id_acquisition_framework", db.Integer, ForeignKey("gn_meta.t_acquisition_frameworks.id_acquisition_framework"), primary_key=True, ), db.Column( "id_nomenclature_voletsinp", db.Integer, ForeignKey(TNomenclatures.id_nomenclature), primary_key=True, ), schema="gn_meta", )
[docs] cor_acquisition_framework_territory = db.Table( "cor_acquisition_framework_territory", db.Column( "id_acquisition_framework", db.Integer, ForeignKey("gn_meta.t_acquisition_frameworks.id_acquisition_framework"), primary_key=True, ), db.Column( "id_nomenclature_territory", db.Integer, ForeignKey(TNomenclatures.id_nomenclature), primary_key=True, ), schema="gn_meta", )
@serializable
[docs] class CorAcquisitionFrameworkActor(DB.Model):
[docs] __tablename__ = "cor_acquisition_framework_actor"
[docs] __table_args__ = {"schema": "gn_meta"}
[docs] id_cafa = DB.Column(DB.Integer, primary_key=True)
[docs] id_acquisition_framework = DB.Column( DB.Integer, ForeignKey("gn_meta.t_acquisition_frameworks.id_acquisition_framework"), )
[docs] id_role = DB.Column(DB.Integer, ForeignKey(User.id_role))
[docs] id_organism = DB.Column(DB.Integer, ForeignKey(Organisme.id_organisme))
[docs] id_nomenclature_actor_role = DB.Column( DB.Integer, ForeignKey("ref_nomenclatures.t_nomenclatures.id_nomenclature"), default=lambda: TNomenclatures.get_default_nomenclature("ROLE_ACTEUR"), )
[docs] nomenclature_actor_role = DB.relationship( TNomenclatures, lazy="joined", primaryjoin=(TNomenclatures.id_nomenclature == id_nomenclature_actor_role), )
[docs] role = DB.relationship( User, lazy="joined", )
[docs] organism = relationship( Organisme, lazy="joined", )
@serializable(exclude=["actor"])
[docs] class CorDatasetActor(DB.Model):
[docs] __tablename__ = "cor_dataset_actor"
[docs] __table_args__ = {"schema": "gn_meta"}
[docs] id_cda = DB.Column(DB.Integer, primary_key=True)
[docs] id_dataset = DB.Column(DB.Integer, ForeignKey("gn_meta.t_datasets.id_dataset"))
[docs] id_role = DB.Column(DB.Integer, ForeignKey(User.id_role))
[docs] id_organism = DB.Column(DB.Integer, ForeignKey(Organisme.id_organisme))
[docs] id_nomenclature_actor_role = DB.Column( DB.Integer, ForeignKey("ref_nomenclatures.t_nomenclatures.id_nomenclature"), default=lambda: TNomenclatures.get_default_nomenclature("ROLE_ACTEUR"), )
[docs] nomenclature_actor_role = DB.relationship( TNomenclatures, lazy="joined", foreign_keys=[id_nomenclature_actor_role], )
[docs] role = DB.relationship(User, lazy="joined")
[docs] organism = DB.relationship(Organisme, lazy="joined")
@hybrid_property
[docs] def actor(self): if self.role is not None: return self.role else: return self.organism
@hybrid_property
[docs] def display(self): if self.role: actor = self.role.nom_complet else: actor = self.organism.nom_organisme return "{} ({})".format(actor, self.nomenclature_actor_role.label_default)
@serializable
[docs] class CorDatasetProtocol(DB.Model): # TODO: replace with table used as secondary in relationships
[docs] __tablename__ = "cor_dataset_protocol"
[docs] __table_args__ = {"schema": "gn_meta"}
[docs] id_cdp = DB.Column(DB.Integer, primary_key=True)
[docs] id_dataset = DB.Column(DB.Integer, ForeignKey("gn_meta.t_datasets.id_dataset"))
[docs] id_protocol = DB.Column(DB.Integer, ForeignKey("gn_meta.sinp_datatype_protocols.id_protocol"))
[docs] cor_dataset_territory = db.Table( "cor_dataset_territory", db.Column( "id_dataset", db.Integer, ForeignKey("gn_meta.t_datasets.id_dataset"), primary_key=True, ), db.Column( "id_nomenclature_territory", db.Integer, ForeignKey(TNomenclatures.id_nomenclature), primary_key=True, ), schema="gn_meta", )
@serializable
[docs] class TBibliographicReference(db.Model):
[docs] __tablename__ = "t_bibliographical_references"
[docs] __table_args__ = {"schema": "gn_meta"}
[docs] id_bibliographic_reference = DB.Column(DB.Integer, primary_key=True)
[docs] id_acquisition_framework = DB.Column( DB.Integer, ForeignKey("gn_meta.t_acquisition_frameworks.id_acquisition_framework"), )
[docs] publication_url = DB.Column(DB.Unicode)
[docs] publication_reference = DB.Column(DB.Unicode)