From aac7bf55d1f6f09146927b22becd434540d5ad91 Mon Sep 17 00:00:00 2001 From: Jaya Surya Date: Thu, 25 Jul 2024 19:58:26 +0530 Subject: [PATCH 1/3] changes for new config --- .DS_Store | Bin 8196 -> 8196 bytes .gitignore | 3 +- CDC_Backend/.DS_Store | Bin 8196 -> 10244 bytes CDC_Backend/APIs/constants.py | 1 + CDC_Backend/APIs/models.py | 4 +- CDC_Backend/APIs/studentViews.py | 18 +++++-- CDC_Backend/APIs/utils.py | 75 +++++++++++++++++----------- CDC_Backend/CDC_Backend/settings.py | 2 +- 8 files changed, 65 insertions(+), 38 deletions(-) diff --git a/.DS_Store b/.DS_Store index b4c80e42b4f70ae56b414c81b32c47570ccce153..a7251e0238e4afbe37dccdc04bc62655457f9194 100644 GIT binary patch delta 869 zcmZp1XmOa}XEU^hRb=42iL2NuSNZ<><>1SHrWX5Bh}MD5t*d;v)~yI(+3j4`%= z0SMR`^cd0^G8sx3G8jr3k|v7@%h#ic<)j-1C+Fval`}AKzQfd&oA2V1l#`zXl;JpF zwLU*v_?RO$RVhTMD#+kPwoYL3YJsGBR-h|08B!Qh84^)lqf-R52T2y$C6levm(@XB zf}#T93hXKhGLRi$0JLDTlc2QM1R)*{ z6oGw0Jj~4E29xatr6<1-;-73PtX9tq^h-WNGOAyso&&9d${-uBQ87O-2jUO7EW!_% zvY75?5NB{@$Yn?bhG7mvJVWv1Ga|g3%Y_dxaB3l zIa4rca-)#=<|H8nMivI!6Q3s62}w;}Ak4$Q*gSsiDxj{1!qSt^q43q28C)Mst`(A= ztR}+G$UiwjSd4=~kD-bolc8YpJ^}g3rXp(0;tZ~n4a6ijKNmT`xUuX4(`I&wZ!D8@ L#jG}#on-<5c}zJ} diff --git a/.gitignore b/.gitignore index 40fddbd..2208f8f 100644 --- a/.gitignore +++ b/.gitignore @@ -143,4 +143,5 @@ dmypy.json dev.env #vscode settings -.vscode/ \ No newline at end of file +.vscode/ +.DS_Store \ No newline at end of file diff --git a/CDC_Backend/.DS_Store b/CDC_Backend/.DS_Store index 7f94099c4577cb0d3b65a1ddf7022978a9c0cc7e..bf7019b9c6e3eebc4cef99312a8535d694c00e90 100644 GIT binary patch literal 10244 zcmeHM&ukyWKCK%5=BLVwu_JuR3WvKI0SJqj&tBpf!K;xD#iGhVkc{lYp;pG z3i7q>Kfs@Wdg-xMPd&7~RI0eNS8klC)CwUX;CnNJGrRUeRjCNX%xdP%?0j$L&G*L7 zo-q+Qg?=qdj#5Xz$8gBJmO~|#Iyp+696ht6PbiL@9eSRGlap7{mX-m_z&HbZ zc6X_S=VLl!p5LpY)iK~>n3gCOD}ks;eHz}}+V|_3Nn^D{?O)+KjjSJ=GX;yz(^=}B z4MbJX#UF2;XW_9-sB!SoxXN~~qj5h}Izh7+W-@;|Q`4z8_RP4hJL`VoH^jCdmcxFp zQ0{)ttxtpqDo^X>%Ee}VyEOOCnrMgRX1m^%3e8#_kV~I7+cmLW5dC(oCv|<*;il8+ z(%gZ;AiF&8<+3X~^WGqvIk}3)%F@nG+TDNTqth2kTS2QWzLpk~qr(`zrP`zN8*@E; zk22z9=Kevm&*cB%<@bO8`KaW7#D&TGr2Yusd#|toBi*Zhw;hP~2Hvrqv)C6!)NArxr7)uEt&T6&8Y& z=puGu!r~$hqjT>iBTe_+4O7?e9hUA(7}s>>^U)F4(oZlV$=;ZwOK@&LP3hhc?(U&h zr7lWtouVAA&?+rah8FQ~J4efOLe?|Xf@T-^EKnV)Q3E+gn{*Pb2Fk0*eQcg4RY*WD z1oBJZJG6jp)xpz4Z3BG*Wq?`x(gGe+V8eylt_9g{kw?cc^Ks~G0tZBNLpsd9xgqyr zW;IF|QiqJF$5KB+XClt@*NxxazCBRkE&;n6@}7r{`YMmR4TeuEkcy zLBd>Fnl8{fR#Zd~Ux!93{^4{U#588%sXpc?Ve~Gzt3j(rjp#g6901IDW`N=S(1cbP z56e@3JR2Ql`p`c>$Hp@`M(>A@#4jA`$56ZMCZi_sx(C*WU^RsO)rd7G{;p%BNWW>z zU;dr^rt)_TvujBbCSu3(Jxl}t@=k7n!$4Y7k25*F29(MB1dWLOANYqRk87@Cap~5# zI?7BK&x|n7Mn+cT>7U!YE}JX^mI2FvWxz6E8F&R4m{vA=eE+|m{Qv(euo7#cWxz7< zUm0*xMZZ{p_R~wL_&|Ku?jc`6=ES(6l2QeQypD&I*YRlZbv)lKGB(4K6Y6;_hf3lN V(u@Byz@Go@`G5Cn^>sY|KLOqFtjGWW delta 140 zcmZn(XmOBWU|?W$DortDU;r^WfEYvza8E20o2aKK$^()I@)T4n*${l zvu|eSVBuio*}O!6g>kcjkR{_}PLa2h=ZT(}yg^)e@ placement.compensation_CTC: + return False, "Can't apply for this Placement, 1.5 times CTC condition not satisfied" for i in PPO: - if int(i.tier) != 1 and int(i.tier) <= int(placement.tier): - return False, "Can't apply for this tier" - elif int(i.tier) == 1 and int(placement.tier) != 1: - return False, "Can't apply for this tier" - - if student.degree != 'bTech' and not placement.rs_eligible: + if 1.5 * i.compensation_CTC > placement.compensation_CTC: + return False, "Can't apply for this Placement, 1.5 times CTC condition not satisfied" + if student.degree not in placement.eligiblestudents: + raise PermissionError("Can't apply for this placement") + if student.degree == 'bTech' and student.batch not in placement.allowed_batch: + raise PermissionError("Can't apply for this placement") + if student.branch not in placement.allowed_branch: + raise PermissionError("Can't apply for this placement") + if student.can_apply == False: raise PermissionError("Can't apply for this placement") return True, "Conditions Satisfied" @@ -275,9 +276,17 @@ def PlacementApplicationConditions(student, placement): def InternshipApplicationConditions(student, internship): try: selected_companies = InternshipApplication.objects.filter(student=student, selected=True) - if len(selected_companies)>=1: - # print("selected companies > 1") + if len(selected_companies) >= 1: return False, "You have already secured a Internship" + if student.degree not in internship.eligiblestudents: + raise PermissionError("Can't apply for this Internship") + if student.branch not in internship.allowed_branch: + raise PermissionError("Can't apply for this Internship") + if student.degree == 'bTech' and student.batch not in internship.allowed_batch: + raise PermissionError("Can't apply for this Internship") + if student.can_apply_internship == False: + raise PermissionError("Can't apply for this Internship") + return True, "Conditions Satisfied" except PermissionError as e: @@ -410,6 +419,8 @@ def placement_eligibility_filters(student, placements): except: logger.warning("Utils - placement_eligibility_filters: " + str(sys.exc_info())) return placements + + def internship_eligibility_filters(student, internships): try: filtered_internships = [] @@ -461,42 +472,48 @@ def send_opening_notifications(opening_id, opening_type=PLACEMENT): logger.warning('Utils - send_opening_notifications: ' + str(sys.exc_info())) return False -def get_eligible_emails(opening_id, opening_type=PLACEMENT,send_all=False): + +def get_eligible_emails(opening_id, opening_type='PLACEMENT', send_all=False): try: - # print(opening_id, opening_type) - if opening_type == PLACEMENT: + if opening_type == 'PLACEMENT': opening = get_object_or_404(Placement, id=opening_id) else: opening = get_object_or_404(Internship, id=opening_id) - emails=[] + + emails = [] students = Student.objects.all() + for student in students.iterator(): - if student.branch in opening.allowed_branch: - if student.degree == 'bTech' or opening.rs_eligible is True: - if (isinstance(opening,Placement) and PlacementApplicationConditions(student, opening)[0]) or ( - isinstance(opening,Internship) and InternshipApplicationConditions(student, opening)[0]): - try: + if student.branch in opening.allowed_branch and student.degree in opening.eligiblestudents: + if student.degree == 'Btech' and student.batch in opening.allowed_batch: + if (isinstance(opening, Placement) and PlacementApplicationConditions(student, opening)[0]) or ( + isinstance(opening, Internship) and InternshipApplicationConditions(student, opening)[0]): + if (opening_type == 'PLACEMENT' and student.can_apply) or ( + opening_type == 'INTERNSHIP' and student.can_apply_internship): student_user = get_object_or_404(User, id=student.id) - #if send_all True send all students eligible for the opening + + # if send_all True send all students eligible for the opening if send_all: emails.append(student_user.email) continue - # check if he applied - if opening_type == PLACEMENT: + + # check if the student applied + if opening_type == 'PLACEMENT': if PlacementApplication.objects.filter(student=student, placement=opening).exists(): continue else: if InternshipApplication.objects.filter(student=student, internship=opening).exists(): continue + emails.append(student_user.email) - except Exception as e: - logger.warning('Utils - send_opening_notifications: For Loop' + str(e)) - return False, [] + return True, emails - except: - logger.warning('Utils - send_opening_notifications: ' + str(sys.exc_info())) + + except Exception as e: + logger.warning('Utils - send_opening_notifications: ' + str(e)) return False, [] + def exception_email(opening): opening = opening.dict() data = { diff --git a/CDC_Backend/CDC_Backend/settings.py b/CDC_Backend/CDC_Backend/settings.py index 174d9c7..ddddada 100644 --- a/CDC_Backend/CDC_Backend/settings.py +++ b/CDC_Backend/CDC_Backend/settings.py @@ -30,7 +30,7 @@ ALLOWED_HOSTS = ['cdc.iitdh.ac.in', 'localhost'] -ADMINS = [ ('Karthik Mv', '200010030@iitdh.ac.in')] +ADMINS = [ ('Jaya Surya', '210020040@iitdh.ac.in')] # Application definition INSTALLED_APPS = [ From c2ebf5a6004a484ff8e10f58b73908170d33e6ff Mon Sep 17 00:00:00 2001 From: Jaya Surya Date: Sun, 28 Jul 2024 19:41:16 +0530 Subject: [PATCH 2/3] added somethings --- CDC_Backend/APIs/utils.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/CDC_Backend/APIs/utils.py b/CDC_Backend/APIs/utils.py index 3c25bf7..02353c4 100644 --- a/CDC_Backend/APIs/utils.py +++ b/CDC_Backend/APIs/utils.py @@ -264,6 +264,12 @@ def PlacementApplicationConditions(student, placement): raise PermissionError("Can't apply for this placement") if student.can_apply == False: raise PermissionError("Can't apply for this placement") + if student.isBacklog == True and placement.backlog_eligible == False: + raise PermissionError("Can't apply for this placement") + if student.isPwd == True and placement.pwd_eligible == False: + raise PermissionError("Can't apply for this placement") + if placement.cpi_eligible > student.cpi: + raise PermissionError("Can't apply for this placement") return True, "Conditions Satisfied" @@ -286,6 +292,12 @@ def InternshipApplicationConditions(student, internship): raise PermissionError("Can't apply for this Internship") if student.can_apply_internship == False: raise PermissionError("Can't apply for this Internship") + if student.isBacklog == True and internship.backlog_eligible == False: + raise PermissionError("Can't apply for this Internship") + if student.isPwd == True and internship.pwd_eligible == False: + raise PermissionError("Can't apply for this Internship") + if internship.cpi_eligible > student.cpi: + raise PermissionError("Can't apply for this Internship") return True, "Conditions Satisfied" From 18c3d9b0465c96251f036c11c0c695332087110d Mon Sep 17 00:00:00 2001 From: NitinVangipuram Date: Sun, 4 Aug 2024 17:25:53 +0530 Subject: [PATCH 3/3] changes to eligibility filter --- CDC_Backend/APIs/companyViews.py | 8 +++----- CDC_Backend/APIs/constants.py | 9 +++++++-- CDC_Backend/APIs/models.py | 4 ++-- CDC_Backend/APIs/studentViews.py | 3 ++- CDC_Backend/APIs/utils.py | 26 +++++++++++++------------- 5 files changed, 27 insertions(+), 23 deletions(-) diff --git a/CDC_Backend/APIs/companyViews.py b/CDC_Backend/APIs/companyViews.py index 6774a13..c7636b7 100644 --- a/CDC_Backend/APIs/companyViews.py +++ b/CDC_Backend/APIs/companyViews.py @@ -84,11 +84,9 @@ def addPlacement(request): # Add a contact person details in the opening opening.contact_person_name = data[CONTACT_PERSON_NAME] # Check if Phone number is Integer - if data[PHONE_NUMBER].isdigit(): - opening.phone_number = int(data[PHONE_NUMBER]) - else: - raise ValueError('Phone number should be integer') - + + opening.phone_number = data[PHONE_NUMBER] + opening.email = data[EMAIL] # Add a company location in the opening diff --git a/CDC_Backend/APIs/constants.py b/CDC_Backend/APIs/constants.py index 435cd1e..8086e90 100644 --- a/CDC_Backend/APIs/constants.py +++ b/CDC_Backend/APIs/constants.py @@ -10,6 +10,7 @@ ['EP', 'EP'], ['CIVIL', 'CIVIL'], ['CHEMICAL', 'CHEMICAL'], + ['MNC','MNC'] ] ELIGIBLE_CHOICES = [ ["Btech", "Btech"], @@ -41,6 +42,7 @@ "2020", ] BATCH_CHOICES = [ + ["2023","2023"], ["2022", "2022"], ["2021", "2021"], ["2020", "2020"], @@ -65,7 +67,7 @@ ['7', 'Tier 7'], ['8', 'Open Tier'], ] - +bTech = 'Btech' # not being used anywhere DEGREE_CHOICES = [ ['bTech', 'B.Tech'], @@ -84,7 +86,10 @@ "satyapriya.gupta@iitdh.ac.in", "dhriti.ghosh@iitdh.ac.in", "suvamay.jana@iitdh.ac.in", - "ramesh.nayaka@iitdh.ac.in" + "ramesh.nayaka@iitdh.ac.in", + "210010003@iitdh.ac.in", + "210010046@iitdh.ac.in", + "210030035@iitdh.ac.in", ] CDC_REPS_EMAILS_FOR_ISSUE=[ #add reps emails "cdc.support@iitdh.ac.in", diff --git a/CDC_Backend/APIs/models.py b/CDC_Backend/APIs/models.py index dff0321..59397ca 100644 --- a/CDC_Backend/APIs/models.py +++ b/CDC_Backend/APIs/models.py @@ -92,7 +92,7 @@ class Placement(models.Model): default=list, blank=True) is_company_details_pdf = models.BooleanField(blank=False, default=False) contact_person_name = models.CharField(blank=False, max_length=JNF_TEXT_MAX_CHARACTER_COUNT) - phone_number = models.PositiveBigIntegerField(blank=False) + phone_number = models.CharField(max_length=15, blank=False) email = models.CharField(blank=False, max_length=JNF_SMALLTEXT_MAX_CHARACTER_COUNT, default="") city = models.CharField(blank=False, max_length=JNF_SMALLTEXT_MAX_CHARACTER_COUNT, default="") state = models.CharField(blank=False, max_length=JNF_SMALLTEXT_MAX_CHARACTER_COUNT, default="") @@ -383,7 +383,7 @@ class Internship(models.Model): is_selection_procedure_details_pdf = models.BooleanField(blank=False, default=False) #contact details of company person contact_person_name = models.CharField(blank=False, max_length=JNF_TEXT_MAX_CHARACTER_COUNT) - phone_number = models.PositiveBigIntegerField(blank=False) + phone_number = models.CharField(max_length=15, blank=False) email = models.EmailField(blank=False) # contact_person_designation = models.CharField(blank=False, max_length=JNF_SMALLTEXT_MAX_CHARACTER_COUNT, default="") # telephone_number = models.PositiveBigIntegerField(blank=True, default=None, null=True) diff --git a/CDC_Backend/APIs/studentViews.py b/CDC_Backend/APIs/studentViews.py index 55ac23a..e833af2 100644 --- a/CDC_Backend/APIs/studentViews.py +++ b/CDC_Backend/APIs/studentViews.py @@ -1,3 +1,4 @@ +from datetime import datetime as dt from rest_framework.decorators import api_view from django.db.models import Q @@ -104,7 +105,7 @@ def getDashboard(request, id, email, user_type): filters = Q( allowed_branch__contains=[studentDetails.branch], eligiblestudents__contains=[studentDetails.degree], - deadline_datetime__gte=datetime.now(), + deadline_datetime__gte=dt.now(), offer_accepted=True, email_verified=True ) diff --git a/CDC_Backend/APIs/utils.py b/CDC_Backend/APIs/utils.py index 02353c4..9224e2c 100644 --- a/CDC_Backend/APIs/utils.py +++ b/CDC_Backend/APIs/utils.py @@ -238,38 +238,38 @@ def PlacementApplicationConditions(student, placement): PPO_PSU = [i for i in PPO if i.tier == 'psu'] # find length of PPO if len(selected_companies) + len(PPO) >= MAX_OFFERS_PER_STUDENT: - raise PermissionError("Max Applications Reached for the Season") + raise PermissionError("Max Applications Reached for the Season1") if len(selected_companies_PSU) > 0: - raise PermissionError('Selected for PSU Can\'t apply anymore') + raise PermissionError('Selected for PSU Can\'t apply anymore2') if len(PPO_PSU) > 0: - raise PermissionError('Selected for PSU Can\'t apply anymore') + raise PermissionError('Selected for PSU Can\'t apply anymore3') if placement.tier == 'psu': return True, "Conditions Satisfied" for i in selected_companies: - if 1.5 * i.compensation_CTC > placement.compensation_CTC: + if 1.5 * i.placement.compensation_CTC > placement.compensation_CTC: return False, "Can't apply for this Placement, 1.5 times CTC condition not satisfied" for i in PPO: - if 1.5 * i.compensation_CTC > placement.compensation_CTC: + if 1.5 * i.compensation > placement.compensation_CTC: return False, "Can't apply for this Placement, 1.5 times CTC condition not satisfied" if student.degree not in placement.eligiblestudents: - raise PermissionError("Can't apply for this placement") - if student.degree == 'bTech' and student.batch not in placement.allowed_batch: - raise PermissionError("Can't apply for this placement") + raise PermissionError("Can't apply for this placement4") + if student.degree == bTech and student.batch not in placement.allowed_batch: + raise PermissionError("Can't apply for this placement5") if student.branch not in placement.allowed_branch: - raise PermissionError("Can't apply for this placement") + raise PermissionError("Can't apply for this placement6") if student.can_apply == False: - raise PermissionError("Can't apply for this placement") + raise PermissionError("Can't apply for this placement7") if student.isBacklog == True and placement.backlog_eligible == False: - raise PermissionError("Can't apply for this placement") + raise PermissionError("Can't apply for this placement8") if student.isPwd == True and placement.pwd_eligible == False: - raise PermissionError("Can't apply for this placement") + raise PermissionError("Can't apply for this placement9") if placement.cpi_eligible > student.cpi: - raise PermissionError("Can't apply for this placement") + raise PermissionError("Can't apply for this placement10") return True, "Conditions Satisfied"