2020-02-26 19:21:59 +00:00
|
|
|
import uuid
|
|
|
|
from datetime import datetime
|
|
|
|
from typing import Union
|
|
|
|
|
|
|
|
from boltons import urlutils
|
|
|
|
from citext import CIText
|
|
|
|
from flask import g
|
|
|
|
from sqlalchemy import TEXT, Enum as DBEnum
|
|
|
|
from sqlalchemy.dialects.postgresql import UUID
|
|
|
|
from sqlalchemy_utils import LtreeType
|
|
|
|
from sqlalchemy_utils.types.ltree import LQUERY
|
|
|
|
from teal.db import CASCADE_OWN, UUIDLtree, check_range, IntEnum
|
|
|
|
from teal.resource import url_for_resource
|
|
|
|
|
|
|
|
from ereuse_devicehub.db import create_view, db, exp, f
|
|
|
|
from ereuse_devicehub.resources.models import Thing
|
|
|
|
from ereuse_devicehub.resources.user.models import User
|
2020-02-29 21:58:49 +00:00
|
|
|
from ereuse_devicehub.resources.lot.models import Lot
|
2020-02-26 19:21:59 +00:00
|
|
|
from ereuse_devicehub.resources.enums import TransferState
|
|
|
|
|
|
|
|
|
2020-02-27 17:29:26 +00:00
|
|
|
class Deliverynote(Thing):
|
2020-02-26 19:21:59 +00:00
|
|
|
id = db.Column(UUID(as_uuid=True), primary_key=True) # uuid is generated on init by default
|
2020-02-29 21:58:49 +00:00
|
|
|
document_id = db.Column(CIText(), nullable=False)
|
|
|
|
creator_id = db.Column(UUID(as_uuid=True),
|
|
|
|
db.ForeignKey(User.id),
|
|
|
|
nullable=False,
|
|
|
|
default=lambda: g.user.id)
|
2020-02-27 17:29:26 +00:00
|
|
|
creator = db.relationship(User, primaryjoin=creator_id == User.id)
|
2020-02-29 21:58:49 +00:00
|
|
|
supplier_email = db.Column(CIText(),
|
|
|
|
db.ForeignKey(User.email),
|
|
|
|
nullable=False,
|
|
|
|
default=lambda: g.user.email)
|
|
|
|
supplier = db.relationship(User, primaryjoin=lambda: Deliverynote.supplier_email == User.email)
|
2020-03-03 12:10:42 +00:00
|
|
|
receiver_address = db.Column(CIText(),
|
|
|
|
db.ForeignKey(User.email))
|
|
|
|
# nullable=False)
|
|
|
|
receiver = db.relationship(User, primaryjoin=lambda: Deliverynote.receiver_address== User.email)
|
2020-02-29 21:58:49 +00:00
|
|
|
# supplier = db.relationship(User)
|
|
|
|
date = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
|
2020-03-03 12:10:42 +00:00
|
|
|
date.comment = 'The date the DeliveryNote initiated'
|
2020-02-26 19:21:59 +00:00
|
|
|
# deposit = db.Column(db.Integer, check_range('deposit', min=0, max=100), default=0)
|
2020-02-27 17:29:26 +00:00
|
|
|
deposit = db.Column(CIText(), nullable=False)
|
|
|
|
# The following fiels are supposed to be 0:N relationships
|
|
|
|
# to SnapshotDelivery entity.
|
|
|
|
# At this stage of implementation they will treated as a
|
|
|
|
# comma-separated string of the devices expexted/transfered
|
|
|
|
expected_devices = db.Column(CIText(), nullable=False)
|
2020-03-03 12:10:42 +00:00
|
|
|
transferred_devices = db.Column(CIText(), nullable=True)
|
2020-02-27 17:29:26 +00:00
|
|
|
transfer_state = db.Column(IntEnum(TransferState), default=TransferState.Initial, nullable=False)
|
|
|
|
transfer_state.comment = TransferState.__doc__
|
2020-03-03 12:10:42 +00:00
|
|
|
ethereum_address = db.Column(CIText(), unique=True, default=None)
|
2020-02-29 21:58:49 +00:00
|
|
|
lot_id = db.Column(UUID(as_uuid=True),
|
|
|
|
db.ForeignKey(Lot.id),
|
|
|
|
nullable=False)
|
2020-02-27 17:29:26 +00:00
|
|
|
lots = db.relationship(Lot,
|
|
|
|
backref=db.backref('deliverynotes', lazy=True, collection_class=set),
|
|
|
|
lazy=True,
|
2020-02-29 21:58:49 +00:00
|
|
|
primaryjoin=Lot.id == lot_id,
|
2020-02-27 17:29:26 +00:00
|
|
|
collection_class=set)
|
2020-02-26 19:21:59 +00:00
|
|
|
|
2020-03-03 12:10:42 +00:00
|
|
|
def __init__(self, document_id: str, deposit: str, date,
|
2020-02-29 21:58:49 +00:00
|
|
|
supplier_email: str,
|
2020-03-03 12:10:42 +00:00
|
|
|
expected_devices: str) -> None:
|
2020-02-26 19:21:59 +00:00
|
|
|
"""Initializes a delivery note
|
|
|
|
"""
|
2020-02-29 21:58:49 +00:00
|
|
|
super().__init__(id=uuid.uuid4(),
|
2020-03-03 12:10:42 +00:00
|
|
|
document_id=document_id, deposit=deposit, date=date,
|
2020-02-29 21:58:49 +00:00
|
|
|
supplier_email=supplier_email,
|
2020-03-03 12:10:42 +00:00
|
|
|
expected_devices=expected_devices)
|
2020-02-26 19:21:59 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def type(self) -> str:
|
|
|
|
return self.__class__.__name__
|
|
|
|
|
|
|
|
@property
|
|
|
|
def url(self) -> urlutils.URL:
|
|
|
|
"""The URL where to GET this action."""
|
2020-02-27 17:29:26 +00:00
|
|
|
return urlutils.URL(url_for_resource(Deliverynote, item_id=self.id))
|
2020-02-26 19:21:59 +00:00
|
|
|
|
2020-03-03 12:10:42 +00:00
|
|
|
def delete(self):
|
|
|
|
"""Deletes the deliverynote.
|
2020-02-26 19:21:59 +00:00
|
|
|
|
2020-03-03 12:10:42 +00:00
|
|
|
This method removes the delivery note.
|
|
|
|
"""
|
|
|
|
db.session.delete(self)
|
2020-02-26 19:21:59 +00:00
|
|
|
|
|
|
|
def __repr__(self) -> str:
|
2020-02-27 17:29:26 +00:00
|
|
|
return '<Deliverynote {0.documentID}>'.format(self)
|