|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- # @name: models.py
- # @creation_date: 2021-10-20
- # @license: The MIT License <https://opensource.org/licenses/MIT>
- # @author: Simon Bowie <ad7588@coventry.ac.uk>
- # @purpose: Database models for tables in the database
- # @acknowledgements:
- # https://www.digitalocean.com/community/tutorials/how-to-add-authentication-to-your-app-with-flask-login
-
- from flask_login import UserMixin
- from . import db
- from datetime import datetime
-
- # table for users
- class User(UserMixin, db.Model):
- __tablename__ = 'User'
-
- id = db.Column(db.Integer, primary_key=True) # primary keys are required by SQLAlchemy
- email = db.Column(db.String(100), unique=True)
- password = db.Column(db.String(1000))
- name = db.Column(db.String(1000))
-
- # table for resources
- class Resource(db.Model):
- __tablename__ = 'Resource'
-
- # all resource types
- id = db.Column(db.Integer, primary_key=True) # primary keys are required by SQLAlchemy
- created = db.Column(db.DateTime, default=datetime.utcnow)
- published = db.Column(db.Boolean)
- type = db.Column(db.Text)
- name = db.Column(db.Text)
- description = db.Column(db.Text)
- videoUrl = db.Column(db.Text)
- # tools
- developer = db.Column(db.Text)
- developerUrl = db.Column(db.Text)
- projectUrl = db.Column(db.Text)
- repositoryUrl = db.Column(db.Text)
- license = db.Column(db.Text)
- scriptingLanguage = db.Column(db.Text)
- expertiseToUse = db.Column(db.Text)
- expertiseToHost = db.Column(db.Text)
- dependencies = db.Column(db.Text)
- ingestFormats = db.Column(db.Text)
- outputFormats = db.Column(db.Text)
- status = db.Column(db.Text)
- # practices
- longDescription = db.Column(db.Text)
- experimental = db.Column(db.Text)
- considerations = db.Column(db.Text)
- references = db.Column(db.Text)
- # books
- author = db.Column(db.Text)
- year = db.Column(db.Text)
- bookUrl = db.Column(db.Text)
- isbn = db.Column(db.Text)
- typology = db.Column(db.Text)
-
- # table for relationships
- class Relationship(db.Model):
- __tablename__ = 'Relationship'
-
- id = db.Column(db.Integer, primary_key=True) # primary keys are required by SQLAlchemy
- first_resource_id = db.Column(db.Integer)
- second_resource_id = db.Column(db.Integer)
|