Exemple #1
0
class SysVars(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'sys_vars'
    id = db.Column(db.Integer, primary_key=True)
    # JSON might be better but SQLite doesn't seem to support it
    var_name = db.Column(db.String(100), nullable=False)
    var_data = db.Column(db.String(100), nullable=True)
Exemple #2
0
class CredentialStore(db.Model):
    __bind_key__ = 'system'
    __tablename__ = 'credential_store'
    id = db.Column(db.Integer, primary_key=True)
    group_id = db.Column(
        db.Integer, db.ForeignKey('credential_group.id'), nullable=False)
    credential_role = db.Column(db.String(100), nullable=False)
    credential_data = db.Column(db.String(100))
Exemple #3
0
class JobParameter(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'job_parameter'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    param_name = db.Column(db.String(50), nullable=False)
    param_display_name = db.Column(db.String(50))
    param_value = db.Column(db.Text)

    job_id = db.Column(db.Integer,
                       db.ForeignKey('saved_jobs.id'),
                       nullable=False)
Exemple #4
0
class PhysicalLocationType(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'physical_location_type'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    subtype = db.Column(db.String(15), nullable=False)  # cloud, local, offsite
    description = db.Column(db.Text)

    physical_locations = db.relationship('PhysicalLocation',
                                         backref='physical_location_type',
                                         lazy=True)
Exemple #5
0
class CredentialGroup(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'credential_group'
    id = db.Column(db.Integer, primary_key=True)
    credentials = db.relationship('CredentialStore',
                                  backref='credential_group',
                                  lazy='subquery')
    description = db.Column(db.String(100))
    service_name = db.Column(db.String(50), nullable=False)
    time_added = db.Column(db.DateTime,
                           nullable=False,
                           default=datetime.utcnow)
Exemple #6
0
class PhysicalLocation(db.Model):
    __bind_key__ = 'backup'
    __tablename__ = 'physical_location'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    address = db.Column(db.Text)
    type = db.Column(db.String(50), nullable=False)
    concurrent_jobs = db.Column(db.Integer, default=1)
    time_added = db.Column(
        db.DateTime,
        nullable=False,
        default=datetime.utcnow)

    repositories = db.relationship(
            'Repository',
            backref='physical_location',
            lazy=True)
Exemple #7
0
class SavedJobs(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'saved_jobs'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String, nullable=False, unique=True)
    notes = db.Column(db.Text)
    engine_name = db.Column(db.String(50), nullable=False)
    engine_class = db.Column(db.String(50), nullable=False)

    last_attempted_run = db.Column(db.DateTime)
    last_successful_run = db.Column(db.DateTime)
    time_added = db.Column(db.DateTime,
                           nullable=False,
                           default=datetime.utcnow)

    db.relationship('JobHistory', backref='saved_job', lazy=True)
    db.relationship('JobParameter', backref='saved_job', lazy=True)
Exemple #8
0
class Engine(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'engine'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    time_added = db.Column(db.DateTime,
                           nullable=False,
                           default=datetime.utcnow)
Exemple #9
0
class BackupSet(db.Model):
    __bind_key__ = 'backup'
    __tablename__ = 'backup_set'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    type = db.Column(db.Integer, nullable=False)
    data = db.Column(db.Text, nullable=False)
    time_added = db.Column(
        db.DateTime,
        nullable=False,
        default=datetime.utcnow)
Exemple #10
0
class Engine(db.Model):
    __bind_key__ = 'backup'
    __tablename__ = 'engine'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    time_added = db.Column(
        db.DateTime,
        nullable=False,
        default=datetime.utcnow)

    repositories = db.relationship(
        'Repository',
        backref='engine'
    )
Exemple #11
0
class Repository(db.Model):
    __bind_key__ = 'backup'
    __tablename__ = 'repository'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    data = db.Column(db.Text)
    time_added = db.Column(
        db.DateTime,
        nullable=False,
        default=datetime.utcnow)

    engine_id = db.Column(
        db.Integer, db.ForeignKey('engine.id'), nullable=False)
    physical_location_id = db.Column(
        db.Integer, db.ForeignKey('physical_location.id'), nullable=False)
Exemple #12
0
class Repository(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'repository'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    description = db.Column(db.Text)
    data = db.Column(db.Text)  # not sure if data is needed
    engine = db.Column(db.String, nullable=False)
    time_added = db.Column(db.DateTime,
                           nullable=False,
                           default=datetime.utcnow)

    physical_location_id = db.Column(db.Integer,
                                     db.ForeignKey('physical_location.id'),
                                     nullable=False)
Exemple #13
0
class BackupSet(db.Model):
    __bind_key__ = 'general'
    __tablename__ = 'backup_set'
    id = db.Column(db.Integer, primary_key=True, nullable=False)
    name = db.Column(db.String(50), nullable=False, unique=True)
    type = db.Column(db.Integer, nullable=False)
    data = db.Column(db.Text)
    source = db.Column(db.String, nullable=True)
    last_good_backup = db.Column(db.DateTime)

    time_added = db.Column(db.DateTime,
                           nullable=False,
                           default=datetime.utcnow)
    backup_objects = db.relationship('BackupObject',
                                     backref='backup_set',
                                     lazy=True)
Exemple #14
0
class User(db.Model, UserMixin):
    __bind_key__ = 'general'
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(20), unique=True, nullable=False)
    password = db.Column(db.String(60), nullable=False)