# -*- coding: utf-8 -*- ################################################################################ # # Rattail -- Retail Software Framework # Copyright © 2010-2017 Lance Edgar # # This file is part of Rattail. # # Rattail is free software: you can redistribute it and/or modify it under the # terms of the GNU Affero General Public License as published by the Free # Software Foundation, either version 3 of the License, or (at your option) # any later version. # # Rattail is distributed in the hope that it will be useful, but WITHOUT ANY # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS # FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for # more details. # # You should have received a copy of the GNU Affero General Public License # along with Rattail. If not, see . # ################################################################################ """ Data models for tempmon """ from __future__ import unicode_literals, absolute_import import datetime import six import sqlalchemy as sa from sqlalchemy import orm from sqlalchemy.ext.declarative import declarative_base from rattail.db.model import uuid_column from rattail.db.model.core import ModelBase Base = declarative_base(cls=ModelBase) @six.python_2_unicode_compatible class Client(Base): """ Represents a tempmon client. """ __tablename__ = 'client' __table_args__ = ( sa.UniqueConstraint('config_key', name='client_uq_config_key'), ) uuid = uuid_column() config_key = sa.Column(sa.String(length=50), nullable=False) hostname = sa.Column(sa.String(length=255), nullable=False) location = sa.Column(sa.String(length=255), nullable=True) delay = sa.Column(sa.Integer(), nullable=True, doc=""" Number of seconds to delay between reading / recording temperatures. If not set, a default of 60 seconds will be assumed. """) enabled = sa.Column(sa.Boolean(), nullable=False, default=False) online = sa.Column(sa.Boolean(), nullable=False, default=False) def __str__(self): return '{} ({})'.format(self.config_key, self.hostname) def enabled_probes(self): return [probe for probe in self.probes if probe.enabled] @six.python_2_unicode_compatible class Probe(Base): """ Represents a probe connected to a tempmon client. """ __tablename__ = 'probe' __table_args__ = ( sa.ForeignKeyConstraint(['client_uuid'], ['client.uuid'], name='probe_fk_client'), sa.UniqueConstraint('config_key', name='probe_uq_config_key'), ) uuid = uuid_column() client_uuid = sa.Column(sa.String(length=32), nullable=False) client = orm.relationship( Client, doc=""" Reference to the tempmon client to which this probe is connected. """, backref=orm.backref( 'probes', doc=""" List of probes connected to this client. """)) config_key = sa.Column(sa.String(length=50), nullable=False) appliance_type = sa.Column(sa.Integer(), nullable=False) description = sa.Column(sa.String(length=255), nullable=False) device_path = sa.Column(sa.String(length=255), nullable=True) enabled = sa.Column(sa.Boolean(), nullable=False, default=True) good_temp_min = sa.Column(sa.Integer(), nullable=False) good_temp_max = sa.Column(sa.Integer(), nullable=False) critical_temp_min = sa.Column(sa.Integer(), nullable=False) critical_temp_max = sa.Column(sa.Integer(), nullable=False) therm_status_timeout = sa.Column(sa.Integer(), nullable=False) status_alert_timeout = sa.Column(sa.Integer(), nullable=False) status = sa.Column(sa.Integer(), nullable=True) status_changed = sa.Column(sa.DateTime(), nullable=True) status_alert_sent = sa.Column(sa.DateTime(), nullable=True) def __str__(self): return self.description @six.python_2_unicode_compatible class Reading(Base): """ Represents a single temperature reading from a tempmon probe. """ __tablename__ = 'reading' __table_args__ = ( sa.ForeignKeyConstraint(['client_uuid'], ['client.uuid'], name='reading_fk_client'), sa.ForeignKeyConstraint(['probe_uuid'], ['probe.uuid'], name='reading_fk_probe'), ) uuid = uuid_column() client_uuid = sa.Column(sa.String(length=32), nullable=False) client = orm.relationship( Client, doc=""" Reference to the tempmon client which took this reading. """) probe_uuid = sa.Column(sa.String(length=32), nullable=False) probe = orm.relationship( Probe, doc=""" Reference to the tempmon probe which took this reading. """) taken = sa.Column(sa.DateTime(), nullable=False, default=datetime.datetime.utcnow) degrees_f = sa.Column(sa.Numeric(precision=7, scale=4), nullable=False) def __str__(self): return str(self.degrees_f)