2022-05-16 20:20:36 +00:00
# Functions dependent on advlabdb.models
2021-07-30 22:12:37 +00:00
from flask import flash , url_for
from flask_admin . menu import MenuLink
2021-06-02 21:43:41 +00:00
from flask_security import current_user
2022-05-16 20:20:36 +00:00
from sqlalchemy import select
2021-04-26 19:31:15 +00:00
2022-05-08 19:26:25 +00:00
from . import app , db
from . models import Semester
2021-03-19 12:41:52 +00:00
2021-05-17 20:36:24 +00:00
2021-07-30 22:12:37 +00:00
def initActiveSemesterMenuLinks ( space ) :
with app . app_context ( ) :
2022-05-17 11:24:16 +00:00
try :
2022-05-29 19:47:23 +00:00
semesters = Semester . sortedSemestersStartingWithNewest ( )
2022-05-17 11:24:16 +00:00
for semester in semesters :
space . add_link (
MenuLink (
name = semester . repr ( ) ,
url = url_for ( " set_semester " ) + " ?semester_id= " + str ( semester . id ) ,
category = " Active semester " ,
)
2021-07-30 22:12:37 +00:00
)
2022-05-17 11:24:16 +00:00
except Exception as ex :
print (
" ERROR: The Semester table does not exist yet! Therefore, menu links could not be generated. You can ignore this error if you are just initializing the database. "
2021-07-30 22:12:37 +00:00
)
2022-05-17 11:24:16 +00:00
else :
space . add_link ( MenuLink ( name = " Logout " , url = url_for ( " security.logout " ) ) )
2021-11-30 00:36:19 +00:00
def reportBadAttempt ( message ) :
print ( " BAD ATTEMPT: " , message ) # TODO: Log
2022-05-16 19:48:04 +00:00
def get_count ( table ) :
return db . session . scalar ( select ( func . count ( ) ) . select_from ( table ) )
2022-05-16 23:28:50 +00:00
def active_semester_repr ( ) :
active_semester = current_user . active_semester
repr = active_semester . repr ( )
2022-05-29 19:47:23 +00:00
if active_semester != Semester . lastSemester ( ) :
2022-05-16 23:28:50 +00:00
flash ( f " You are in the old semester { repr } ! " , " warning " )
return repr