Exemple #1
0
class Set(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(32), db.ForeignKey('user.username'))
    name = db.Column(db.String(50))
    start = db.Column(db.Integer)
    end = db.Column(db.Integer)
    low_or_high = db.Column(db.String(
        4))  # Whether this set contains 'low', 'high', or 'any' observations.
    eor = db.Column(db.String(
        4))  # Whether this set contains 'EOR0', 'EOR1', or 'any' observations.
    total_data_hrs = db.Column(db.Float)
    flagged_data_hrs = db.Column(db.Float)
    created_on = db.Column(db.DateTime, default=datetime.utcnow)
Exemple #2
0
class Post(db.Model):

    """A blog post."""

    id = db.Column(db.Integer, primary_key=True)

    # Wordpress stuff.
    post_id = db.Column(db.Integer, unique=True)
    status = db.Column(db.Unicode)
    title = db.Column(db.Unicode)
    content = db.Column(db.Unicode)
    epoch = db.Column(db.Integer)
    link = db.Column(db.Unicode)
    location = db.Column(db.Unicode)

    # These may be real or may be synthetic based off GPS positions.
    latitude = db.Column(db.Float)
    longitude = db.Column(db.Float)
Exemple #3
0
class GraphDataSource(db.Model):
    name = db.Column(db.String(100), primary_key=True)
    graph_type = db.Column(db.String(100), db.ForeignKey('graph_type.name'))
    host = db.Column(db.String(100))
    database = db.Column(db.String(100))
    table = db.Column(db.String(100))
    obs_column = db.Column(
        db.String(100))  # Which column has the observation ids.
    projectid = db.Column(
        db.Boolean)  # Whether the table has a projectid field.
    width_slider = db.Column(
        db.Boolean
    )  # Whether the graph should come with a column width slider.
Exemple #4
0
class GraphData(db.Model):
    # AUTO_INCREMENT is automatically set on the first Integer primary key column that is not marked as a foreign key.
    id = db.Column(db.Integer, primary_key=True)
    # Store a 'created_on' string field for the current time that is automatically inserted with a new entry into the database.
    # We're using UTC time, so that's why there is a Z at the end of the string.
    created_on = db.Column(db.DateTime, default=datetime.utcnow)
    hours_scheduled = db.Column(db.Float)
    hours_observed = db.Column(db.Float)
    hours_with_data = db.Column(db.Float)
    hours_with_uvfits = db.Column(db.Float)
    data_transfer_rate = db.Column(db.Float)

    def asDict(self):
        return {
            'id': self.id,
            'created_on': self.created_on,
            'hours_scheduled': round(self.hours_scheduled or 0., 4),
            'hours_observed': round(self.hours_observed or 0., 4),
            'hours_with_data': round(self.hours_with_data or 0., 4),
            'hours_with_uvfits': round(self.hours_with_uvfits or 0., 4),
            'data_transfer_rate': round(self.data_transfer_rate or 0., 4)
        }
Exemple #5
0
class User(db.Model):
    username = db.Column(db.String(32), primary_key=True)
    # SHA-512 returns a 512-bit hash, which is 512 bits / 8 bits per byte * 2 hex digits per byte = 128 hex digits.
    password = db.Column(db.String(128), nullable=False)
    # 254 is the maximum length of an email address.
    email = db.Column(db.String(254), nullable=False)
    first_name = db.Column(db.String(50), nullable=False)
    last_name = db.Column(db.String(50), nullable=False)
    owned_sets = db.relationship('Set', backref='user')
    subscribed_sets = db.relationship('Set', secondary=set_subscriptions)
    subscribed_data_sources = db.relationship(
        'GraphDataSource', secondary=data_source_subscriptions)
    active_data_sources = db.relationship('GraphDataSource',
                                          secondary=active_data_sources)
    admin = db.Column(db.Boolean, default=False)

    def __init__(self, username, password, email, first_name, last_name):
        self.username = username
        self.password = password
        self.email = email
        self.first_name = first_name
        self.last_name = last_name

    def __repr__(self):
        return '<User %r>' % (self.username)

    def is_authenticated(self):
        return True

    def is_active(self):
        return True

    def is_anonymous(self):
        return False

    def get_id(self):
        return self.username
Exemple #6
0
class Position(db.Model):
    """A GPS point for a given feed that may include additional info."""

    id = db.Column(db.Integer, primary_key=True)
    epoch = db.Column(db.Integer, unique=True)
    latitude = db.Column(db.Float)
    longitude = db.Column(db.Float)
    # Future thoughts:
    # If we go with a Feed model:
    # feed = db.Column(db.Integer, db.ForeignKey('Feed.id'))

    # Geo information:
    country = db.Column(db.Unicode)
    state = db.Column(db.Unicode)
    city = db.Column(db.Unicode)
    # I think there's more, see https://pypi.python.org/pypi/geolocation-python

    # Movement information:
    distance_from_prev = db.Column(db.Float)
    time_from_prev = db.Column(db.Float)
    speed_from_prev = db.Column(db.Float)

    # Weather information, although this might want to be elsewhere.
    temperature = db.Column(db.Float)
    apparent_temperature = db.Column(db.Float)  # "Feels like"
    humidity = db.Column(db.Float)
    precip_probability = db.Column(db.Float)
    precip_intensity = db.Column(db.Float)
    weather_summary = db.Column(db.Unicode)
    precip_type = db.Column(db.Unicode)
    wind_speed = db.Column(db.Unicode)
Exemple #7
0
class FlaggedObsIds(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    obs_id = db.Column(db.Integer)
    flagged_subset_id = db.Column(
        db.Integer, db.ForeignKey('flagged_subset.id', ondelete="CASCADE"))
Exemple #8
0
class FlaggedSubset(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    set_id = db.Column(db.Integer, db.ForeignKey('set.id', ondelete="CASCADE"))
    start = db.Column(db.Integer)
    end = db.Column(db.Integer)
Exemple #9
0
class GraphDataSourceColumn(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    graph_data_source = db.Column(db.String(100),
                                  db.ForeignKey('graph_data_source.name'))
    name = db.Column(db.String(100))
Exemple #10
0
class GraphType(db.Model):
    name = db.Column(db.String(100), primary_key=True)
Exemple #11
0
class Comment(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    thread_id = db.Column(db.Integer, db.ForeignKey('thread.id'))
    text = db.Column(db.String(1000), nullable=False)
    username = db.Column(db.String(32), db.ForeignKey('user.username'))
    created_on = db.Column(db.DateTime, default=datetime.utcnow)
Exemple #12
0
class Thread(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100), nullable=False)
    username = db.Column(db.String(32), db.ForeignKey('user.username'))
    created_on = db.Column(db.DateTime, default=datetime.utcnow)
    last_updated = db.Column(db.DateTime, default=datetime.utcnow)
Exemple #13
0
from app.flask_app import db
from datetime import datetime

set_subscriptions = db.Table(
    'set_subscriptions',
    db.Column('username', db.String(32), db.ForeignKey('user.username')),
    db.Column('set_id', db.Integer, db.ForeignKey('set.id')))

data_source_subscriptions = db.Table(
    'data_source_subscriptions',
    db.Column('username', db.String(32), db.ForeignKey('user.username')),
    db.Column('data_source', db.String(100),
              db.ForeignKey('graph_data_source.name')))

active_data_sources = db.Table(
    'active_data_sources',
    db.Column('username', db.String(32), db.ForeignKey('user.username')),
    db.Column('data_source', db.String(100),
              db.ForeignKey('graph_data_source.name')))


class User(db.Model):
    username = db.Column(db.String(32), primary_key=True)
    # SHA-512 returns a 512-bit hash, which is 512 bits / 8 bits per byte * 2 hex digits per byte = 128 hex digits.
    password = db.Column(db.String(128), nullable=False)
    # 254 is the maximum length of an email address.
    email = db.Column(db.String(254), nullable=False)
    first_name = db.Column(db.String(50), nullable=False)
    last_name = db.Column(db.String(50), nullable=False)
    owned_sets = db.relationship('Set', backref='user')
    subscribed_sets = db.relationship('Set', secondary=set_subscriptions)