|
|
|
from datetime import datetime
|
|
|
|
from ispoof.spoofer.location import Location
|
|
|
|
from sqlalchemy import Column, String, Integer, Boolean, DateTime, PrimaryKeyConstraint
|
|
|
|
from sqlalchemy.orm import declarative_base
|
|
|
|
|
|
|
|
Base = declarative_base()
|
|
|
|
|
|
|
|
class Raid(Base):
|
|
|
|
__tablename__ = "raid"
|
|
|
|
|
|
|
|
name = Column(String(30))
|
|
|
|
number = Column(Integer)
|
|
|
|
location = Column(Location)
|
|
|
|
level = Column(Integer)
|
|
|
|
start_time = Column(DateTime)
|
|
|
|
end_time = Column(DateTime)
|
|
|
|
country = Column(String(2))
|
|
|
|
PrimaryKeyConstraint(name, location, start_time, end_time, name="raid_pk", sqlite_on_conflict='IGNORE')
|
|
|
|
|
|
|
|
def __init__(self, name, number, level, location, start_time, end_time, country):
|
|
|
|
self.name = name
|
|
|
|
self.number = number
|
|
|
|
self.level = level
|
|
|
|
self.location = location
|
|
|
|
self.start_time = start_time
|
|
|
|
self.end_time = end_time
|
|
|
|
self.country = country
|
|
|
|
|
|
|
|
def is_dispawned(self) -> bool:
|
|
|
|
if datetime().now() > self.end_time:
|
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
|
|
def __repr__(self) -> str:
|
|
|
|
return f"(Raid: {self.name} - {self.level}-star - {self.location} - Start: {self.start_time} - End: {self.end_time})"
|
|
|
|
|