Coverage for app/logic/utils.py: 65%

49 statements  

« prev     ^ index     » next       coverage.py v7.2.7, created at 2024-09-06 19:35 +0000

1from datetime import datetime 

2import collections.abc as collections 

3 

4from flask import session 

5from peewee import DoesNotExist 

6 

7from app.models.term import Term 

8 

9def selectSurroundingTerms(currentTerm, prevTerms=2): 

10 """ 

11 Returns a list of term objects around the provided Term object for the current term. 

12 Chooses the previous terms according to the prevTerms parameter (defaulting to 2), 

13 and then chooses terms for the next two years after the current term. 

14 

15 To get only the current and future terms, pass prevTerms=0. 

16 """ 

17 

18 # Find the starting term 

19 startOrder = currentTerm.termOrder 

20 while(prevTerms > 0): 

21 orderPieces = startOrder.split('-') 

22 if(orderPieces[1] == "1"): 

23 orderPieces[0] = int(orderPieces[0]) - 1 

24 orderPieces[1] = 3 

25 else: 

26 orderPieces[1] = int(orderPieces[1]) - 1 

27 startOrder = f"{orderPieces[0]}-{orderPieces[1]}" 

28 

29 prevTerms -= 1 

30 

31 surroundingTerms = (Term.select() 

32 .where(Term.termOrder >= startOrder) 

33 .where((Term.year <= currentTerm.year + 2)) 

34 .order_by(Term.termOrder)) 

35 

36 return surroundingTerms 

37 

38def getStartofCurrentAcademicYear(currentTerm): 

39 if ("Summer" in currentTerm.description) or ("Spring" in currentTerm.description): 

40 fallTerm = Term.select().where(Term.year==currentTerm.year-1, Term.description == f"Fall {currentTerm.year-1}").get() 

41 return fallTerm 

42 return currentTerm 

43 

44def format24HourTime(unformattedTime): 

45 """ 

46 Turns a time string or datetime object into a string with a time in 24 hour format 

47 unformattedTime: expects a string with format HH:mm AM/PM or HH:mm OR a datetime object 

48 returns: a string in 24 hour format HH:mm 

49 """ 

50 if type(unformattedTime) == str: 

51 try: 

52 formattedTime = datetime.strptime(unformattedTime, "%I:%M %p").strftime("%H:%M") # Converts string to datetime then back to string and formats correctly 

53 return formattedTime 

54 except ValueError: 

55 # calling strptime here to explicitly raise an exception if it wasn't properly in 24 hour format 

56 formattedTime = datetime.strptime(unformattedTime, "%H:%M") 

57 return unformattedTime 

58 else: 

59 formattedTime = unformattedTime.strftime("%H:%M") 

60 return formattedTime 

61 

62def getUsernameFromEmail(email): 

63 return email.split("@")[0] 

64 

65def getFilesFromRequest(request): 

66 attachmentFiles = request.files.getlist("attachmentObject") 

67 fileDoesNotExist = attachmentFiles[0].content_type == "application/octet-stream" 

68 if fileDoesNotExist: 

69 attachmentFiles = None 

70 

71 return attachmentFiles 

72 

73def getRedirectTarget(popTarget=False): 

74 """ 

75 This function returns a string with the URL or route to a page in the Application 

76 saved with setRedirectTarget() and is able to pop the value from the session 

77 to make it an empty value 

78 popTarget: expects a bool value to determine whether or not to reset 

79 redirectTarget to an emtpy value 

80 return: a string with the URL or route to a page in the application that was 

81 saved in setRedirectTarget() 

82 """ 

83 if "redirectTarget" not in session: 

84 return '' 

85 

86 target = session["redirectTarget"] 

87 if popTarget: 

88 session.pop("redirectTarget") 

89 return target 

90 

91def setRedirectTarget(target): 

92 """ 

93 This function saves the target URL in the session for future redirection 

94 to said page 

95 target: expects a string that is a URL or a route to a page in the application 

96 return: None 

97 """ 

98 session["redirectTarget"] = target 

99