Merge branch 'main' into Updated_appilication
This commit is contained in:
commit
0488e3e334
|
@ -1,4 +1,5 @@
|
||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
|
from simple_history.admin import SimpleHistoryAdmin
|
||||||
from django.contrib.admin.templatetags.admin_urls import admin_urlname
|
from django.contrib.admin.templatetags.admin_urls import admin_urlname
|
||||||
from django.shortcuts import resolve_url
|
from django.shortcuts import resolve_url
|
||||||
from django.utils.html import format_html
|
from django.utils.html import format_html
|
||||||
|
@ -6,8 +7,8 @@ from django.utils.safestring import SafeText
|
||||||
|
|
||||||
from .models import *
|
from .models import *
|
||||||
|
|
||||||
admin.site.register(User)
|
admin.site.register(User, SimpleHistoryAdmin)
|
||||||
admin.site.register(Admin)
|
admin.site.register(Admin, SimpleHistoryAdmin)
|
||||||
|
|
||||||
admin.site.site_header = "CDC Recruitment Portal"
|
admin.site.site_header = "CDC Recruitment Portal"
|
||||||
|
|
||||||
|
@ -18,7 +19,7 @@ def model_admin_url(obj, name=None) -> str:
|
||||||
|
|
||||||
|
|
||||||
@admin.register(Student)
|
@admin.register(Student)
|
||||||
class Student(admin.ModelAdmin):
|
class Student(SimpleHistoryAdmin):
|
||||||
list_display = ("roll_no", "name", "batch", "branch", "phone_number", 'can_apply')
|
list_display = ("roll_no", "name", "batch", "branch", "phone_number", 'can_apply')
|
||||||
search_fields = ("roll_no", "name", "phone_number")
|
search_fields = ("roll_no", "name", "phone_number")
|
||||||
ordering = ("roll_no", "name", "batch", "branch", "phone_number")
|
ordering = ("roll_no", "name", "batch", "branch", "phone_number")
|
||||||
|
@ -37,7 +38,7 @@ class Student(admin.ModelAdmin):
|
||||||
|
|
||||||
|
|
||||||
@admin.register(Placement)
|
@admin.register(Placement)
|
||||||
class Placement(admin.ModelAdmin):
|
class Placement(SimpleHistoryAdmin):
|
||||||
list_display = (COMPANY_NAME, CONTACT_PERSON_NAME, PHONE_NUMBER, 'tier', 'compensation_CTC')
|
list_display = (COMPANY_NAME, CONTACT_PERSON_NAME, PHONE_NUMBER, 'tier', 'compensation_CTC')
|
||||||
search_fields = (COMPANY_NAME, CONTACT_PERSON_NAME)
|
search_fields = (COMPANY_NAME, CONTACT_PERSON_NAME)
|
||||||
ordering = (COMPANY_NAME, CONTACT_PERSON_NAME, 'tier', 'compensation_CTC')
|
ordering = (COMPANY_NAME, CONTACT_PERSON_NAME, 'tier', 'compensation_CTC')
|
||||||
|
@ -45,7 +46,7 @@ class Placement(admin.ModelAdmin):
|
||||||
|
|
||||||
|
|
||||||
@admin.register(PlacementApplication)
|
@admin.register(PlacementApplication)
|
||||||
class PlacementApplication(admin.ModelAdmin):
|
class PlacementApplication(SimpleHistoryAdmin):
|
||||||
list_display = ('id', 'Placement', 'Student', 'selected')
|
list_display = ('id', 'Placement', 'Student', 'selected')
|
||||||
search_fields = ('id',)
|
search_fields = ('id',)
|
||||||
ordering = ('id',)
|
ordering = ('id',)
|
||||||
|
@ -59,7 +60,7 @@ class PlacementApplication(admin.ModelAdmin):
|
||||||
|
|
||||||
|
|
||||||
@admin.register(PrePlacementOffer)
|
@admin.register(PrePlacementOffer)
|
||||||
class PrePlacementOffer(admin.ModelAdmin):
|
class PrePlacementOffer(SimpleHistoryAdmin):
|
||||||
list_display = ('company', 'Student', 'accepted')
|
list_display = ('company', 'Student', 'accepted')
|
||||||
search_fields = ('company',)
|
search_fields = ('company',)
|
||||||
ordering = ('company',)
|
ordering = ('company',)
|
||||||
|
|
|
@ -8,7 +8,8 @@ urlpatterns = [
|
||||||
path('updateDeadline/', adminViews.updateDeadline, name="Update Deadline"),
|
path('updateDeadline/', adminViews.updateDeadline, name="Update Deadline"),
|
||||||
path('updateOfferAccepted/', adminViews.updateOfferAccepted, name="Update Offer Accepted"),
|
path('updateOfferAccepted/', adminViews.updateOfferAccepted, name="Update Offer Accepted"),
|
||||||
path('updateEmailVerified', adminViews.updateEmailVerified, name="Update Email Verified"),
|
path('updateEmailVerified', adminViews.updateEmailVerified, name="Update Email Verified"),
|
||||||
path('updateAdditionalInfo/', adminViews.updateAdditionalInfo, name="Update Additional Info"),
|
path('deleteAdditionalInfo/', adminViews.deleteAdditionalInfo, name="Delete Additional Info"),
|
||||||
|
path('addAdditionalInfo/', adminViews.addAdditionalInfo, name="Add Additional Info"),
|
||||||
path('getApplications/', adminViews.getApplications, name="Get Applications"),
|
path('getApplications/', adminViews.getApplications, name="Get Applications"),
|
||||||
path("submitApplication/", adminViews.submitApplication, name="Submit Application"),
|
path("submitApplication/", adminViews.submitApplication, name="Submit Application"),
|
||||||
path('generateCSV/', adminViews.generateCSV, name="Generate CSV"),
|
path('generateCSV/', adminViews.generateCSV, name="Generate CSV"),
|
||||||
|
|
|
@ -39,6 +39,7 @@ def markStatus(request, id, email, user_type):
|
||||||
sendEmail(email, subject, data, STUDENT_APPLICATION_STATUS_SELECTED_TEMPLATE)
|
sendEmail(email, subject, data, STUDENT_APPLICATION_STATUS_SELECTED_TEMPLATE)
|
||||||
else:
|
else:
|
||||||
sendEmail(email, subject, data, STUDENT_APPLICATION_STATUS_NOT_SELECTED_TEMPLATE)
|
sendEmail(email, subject, data, STUDENT_APPLICATION_STATUS_NOT_SELECTED_TEMPLATE)
|
||||||
|
application.chaged_by = get_object_or_404(User, id=id)
|
||||||
application.save()
|
application.save()
|
||||||
else:
|
else:
|
||||||
raise ValueError("Student - " + i[STUDENT_ID] + " didn't apply for this opening")
|
raise ValueError("Student - " + i[STUDENT_ID] + " didn't apply for this opening")
|
||||||
|
@ -89,6 +90,7 @@ def updateDeadline(request, id, email, user_type):
|
||||||
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
||||||
# Updating deadline date with correct format in datetime field
|
# Updating deadline date with correct format in datetime field
|
||||||
opening.deadline_datetime = datetime.datetime.strptime(data[DEADLINE_DATETIME], '%Y-%m-%d %H:%M:%S %z')
|
opening.deadline_datetime = datetime.datetime.strptime(data[DEADLINE_DATETIME], '%Y-%m-%d %H:%M:%S %z')
|
||||||
|
opening.changed_by = get_object_or_404(User, id=id)
|
||||||
opening.save()
|
opening.save()
|
||||||
return Response({'action': "Update Deadline", 'message': "Deadline Updated"},
|
return Response({'action': "Update Deadline", 'message': "Deadline Updated"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
@ -111,6 +113,7 @@ def updateOfferAccepted(request, id, email, user_type):
|
||||||
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
||||||
opening.offer_accepted = True if data[OFFER_ACCEPTED] == True else False
|
opening.offer_accepted = True if data[OFFER_ACCEPTED] == True else False
|
||||||
print(opening.offer_accepted)
|
print(opening.offer_accepted)
|
||||||
|
opening.changed_by = get_object_or_404(User, id=id)
|
||||||
opening.save()
|
opening.save()
|
||||||
return Response({'action': "Update Offer Accepted", 'message': "Offer Accepted Updated"},
|
return Response({'action': "Update Offer Accepted", 'message': "Offer Accepted Updated"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
@ -131,6 +134,7 @@ def updateEmailVerified(request, id, email, user_type):
|
||||||
data = request.data
|
data = request.data
|
||||||
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
||||||
opening.email_verified = True if data[EMAIL_VERIFIED] == "true" else False
|
opening.email_verified = True if data[EMAIL_VERIFIED] == "true" else False
|
||||||
|
opening.changed_by = get_object_or_404(User, id=id)
|
||||||
opening.save()
|
opening.save()
|
||||||
return Response({'action': "Update Email Verified", 'message': "Email Verified Updated"},
|
return Response({'action': "Update Email Verified", 'message': "Email Verified Updated"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
@ -145,32 +149,58 @@ def updateEmailVerified(request, id, email, user_type):
|
||||||
|
|
||||||
@api_view(['POST'])
|
@api_view(['POST'])
|
||||||
@isAuthorized([ADMIN])
|
@isAuthorized([ADMIN])
|
||||||
@precheck([OPENING_ID, ADDITIONAL_INFO])
|
@precheck([OPENING_ID, FIELD])
|
||||||
def updateAdditionalInfo(request, id, email, user_type):
|
def deleteAdditionalInfo(request, id, email, user_type):
|
||||||
try:
|
try:
|
||||||
data = request.data
|
data = request.data
|
||||||
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
||||||
if data[ADDITIONAL_INFO] == "":
|
if data[FIELD] in opening.additional_info:
|
||||||
opening.additional_info = []
|
opening.additional_info.remove(data[FIELD])
|
||||||
elif isinstance(data[ADDITIONAL_INFO], list):
|
opening.changed_by = get_object_or_404(User, id=id)
|
||||||
opening.additional_info = data[ADDITIONAL_INFO]
|
|
||||||
else:
|
|
||||||
raise ValueError("Additional Info must be a list")
|
|
||||||
opening.save()
|
opening.save()
|
||||||
return Response({'action': "Update Additional Info", 'message': "Additional Info Updated"},
|
return Response({'action': "Delete Additional Info", 'message': "Additional Info Deleted"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
else:
|
||||||
|
raise ValueError("Additional Info Not Found")
|
||||||
except Http404:
|
except Http404:
|
||||||
return Response({'action': "Update Additional Info", 'message': 'Opening Not Found'},
|
return Response({'action': "Delete Additional Info", 'message': 'Opening Not Found'},
|
||||||
status=status.HTTP_404_NOT_FOUND)
|
status=status.HTTP_404_NOT_FOUND)
|
||||||
except ValueError:
|
except ValueError:
|
||||||
return Response({'action': "Update Additional Info", 'message': "Additional Info must be a list"},
|
return Response({'action': "Delete Additional Info", 'message': "Additional Info not found"},
|
||||||
|
status=status.HTTP_404_NOT_FOUND)
|
||||||
|
except Exception as e:
|
||||||
|
logger.warning("Delete Additional Info: " + str(e))
|
||||||
|
return Response({'action': "Delete Additional Info", 'message': "Something went wrong"},
|
||||||
|
status=status.HTTP_400_BAD_REQUEST)
|
||||||
|
|
||||||
|
@api_view(['POST'])
|
||||||
|
@isAuthorized([ADMIN])
|
||||||
|
@precheck([OPENING_ID, FIELD])
|
||||||
|
def addAdditionalInfo(request, id, email, user_type):
|
||||||
|
try:
|
||||||
|
data = request.data
|
||||||
|
opening = get_object_or_404(Placement, pk=data[OPENING_ID])
|
||||||
|
if data[FIELD] not in opening.additional_info:
|
||||||
|
opening.additional_info.append(data[FIELD])
|
||||||
|
opening.save()
|
||||||
|
return Response({'action': "Add Additional Info", 'message': "Additional Info Added"},
|
||||||
|
status=status.HTTP_200_OK)
|
||||||
|
else:
|
||||||
|
raise ValueError("Additional Info Found")
|
||||||
|
|
||||||
|
except Http404:
|
||||||
|
return Response({'action': "Add Additional Info", 'message': 'Opening Not Found'},
|
||||||
|
status=status.HTTP_404_NOT_FOUND)
|
||||||
|
except ValueError:
|
||||||
|
return Response({'action': "Add Additional Info", 'message': "Additional Info already found"},
|
||||||
status=status.HTTP_400_BAD_REQUEST)
|
status=status.HTTP_400_BAD_REQUEST)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.warning("Update Additional Info: " + str(e))
|
logger.warning("Add Additional Info: " + str(e))
|
||||||
return Response({'action': "Update Additional Info", 'message': "Something went wrong"},
|
return Response({'action': "Add Additional Info", 'message': "Something went wrong"},
|
||||||
status=status.HTTP_400_BAD_REQUEST)
|
status=status.HTTP_400_BAD_REQUEST)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@api_view(['GET'])
|
@api_view(['GET'])
|
||||||
@isAuthorized([ADMIN])
|
@isAuthorized([ADMIN])
|
||||||
@precheck([OPENING_ID])
|
@precheck([OPENING_ID])
|
||||||
|
@ -223,6 +253,7 @@ def submitApplication(request, id, email, user_type):
|
||||||
"application_type": "Placement",
|
"application_type": "Placement",
|
||||||
"additional_info": dict(json.loads(application.additional_info)),
|
"additional_info": dict(json.loads(application.additional_info)),
|
||||||
}
|
}
|
||||||
|
application.changed_by = get_object_or_404(User, id=id)
|
||||||
application.save()
|
application.save()
|
||||||
sendEmail(user.email, STUDENT_APPLICATION_SUBMITTED_TEMPLATE_SUBJECT, data, STUDENT_APPLICATION_SUBMITTED_TEMPLATE)
|
sendEmail(user.email, STUDENT_APPLICATION_SUBMITTED_TEMPLATE_SUBJECT, data, STUDENT_APPLICATION_SUBMITTED_TEMPLATE)
|
||||||
return Response({'action': "Add Student Application", 'message': "Application added"},
|
return Response({'action': "Add Student Application", 'message': "Application added"},
|
||||||
|
@ -249,6 +280,7 @@ def submitApplication(request, id, email, user_type):
|
||||||
"application_type": "Placement",
|
"application_type": "Placement",
|
||||||
"additional_info": dict(json.loads(application.additional_info)),
|
"additional_info": dict(json.loads(application.additional_info)),
|
||||||
}
|
}
|
||||||
|
application.changed_by = get_object_or_404(User, id=id)
|
||||||
application.save()
|
application.save()
|
||||||
sendEmail(user.email, STUDENT_APPLICATION_UPDATED_TEMPLATE_SUBJECT, data, STUDENT_APPLICATION_UPDATED_TEMPLATE)
|
sendEmail(user.email, STUDENT_APPLICATION_UPDATED_TEMPLATE_SUBJECT, data, STUDENT_APPLICATION_UPDATED_TEMPLATE)
|
||||||
return Response({'action': "Add Student Application", 'message': "Application updated"},
|
return Response({'action': "Add Student Application", 'message': "Application updated"},
|
||||||
|
@ -340,6 +372,7 @@ def addPPO(request, id, email, user_type):
|
||||||
PPO.tier = data[TIER]
|
PPO.tier = data[TIER]
|
||||||
if COMPENSATION_DETAILS in data:
|
if COMPENSATION_DETAILS in data:
|
||||||
PPO.compensation_details = data[COMPENSATION_DETAILS]
|
PPO.compensation_details = data[COMPENSATION_DETAILS]
|
||||||
|
PPO.changed_by = get_object_or_404(User, id=id)
|
||||||
PPO.save()
|
PPO.save()
|
||||||
return Response({'action': "Add PPO", 'message': "PPO added"},
|
return Response({'action': "Add PPO", 'message': "PPO added"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
|
|
@ -70,6 +70,7 @@ RESUME_FILE_NAME = 'resume_file_name'
|
||||||
APPLICATION_ID = "application_id"
|
APPLICATION_ID = "application_id"
|
||||||
OPENING_ID = "opening_id"
|
OPENING_ID = "opening_id"
|
||||||
ADDITIONAL_INFO = "additional_info"
|
ADDITIONAL_INFO = "additional_info"
|
||||||
|
FIELD = "field"
|
||||||
|
|
||||||
STATUS_ACCEPTING_APPLICATIONS = "Accepting Applications"
|
STATUS_ACCEPTING_APPLICATIONS = "Accepting Applications"
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
from django.contrib.postgres.fields import ArrayField
|
from django.contrib.postgres.fields import ArrayField
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
|
from simple_history.models import HistoricalRecords
|
||||||
|
|
||||||
from .constants import *
|
from .constants import *
|
||||||
|
|
||||||
|
@ -13,6 +14,7 @@ class User(models.Model):
|
||||||
id = models.CharField(blank=False, max_length=25, index=True, unique=True)
|
id = models.CharField(blank=False, max_length=25, index=True, unique=True)
|
||||||
user_type = ArrayField(models.CharField(blank=False, max_length=10), size=4, default=list, blank=False)
|
user_type = ArrayField(models.CharField(blank=False, max_length=10), size=4, default=list, blank=False)
|
||||||
last_login_time = models.DateTimeField(default=timezone.now)
|
last_login_time = models.DateTimeField(default=timezone.now)
|
||||||
|
history = HistoricalRecords()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name_plural = "User"
|
verbose_name_plural = "User"
|
||||||
|
@ -30,14 +32,41 @@ class Student(models.Model):
|
||||||
default=list, blank=True)
|
default=list, blank=True)
|
||||||
cpi = models.DecimalField(decimal_places=2, max_digits=4)
|
cpi = models.DecimalField(decimal_places=2, max_digits=4)
|
||||||
can_apply = models.BooleanField(default=True, verbose_name='Registered')
|
can_apply = models.BooleanField(default=True, verbose_name='Registered')
|
||||||
|
changed_by = models.ForeignKey(User, blank=True, on_delete=models.RESTRICT, default=None, null=True)
|
||||||
|
history = HistoricalRecords(user_model=User)
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return str(self.roll_no)
|
return str(self.roll_no)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _history_user(self):
|
||||||
|
return self.changed_by
|
||||||
|
|
||||||
|
@_history_user.setter
|
||||||
|
def _history_user(self, value):
|
||||||
|
if isinstance(value, User):
|
||||||
|
self.changed_by = value
|
||||||
|
else:
|
||||||
|
self.changed_by = None
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class Admin(models.Model):
|
class Admin(models.Model):
|
||||||
id = models.CharField(blank=False, max_length=15, primary_key=True)
|
id = models.CharField(blank=False, max_length=15, primary_key=True)
|
||||||
name = models.CharField(blank=False, max_length=JNF_TEXT_MAX_CHARACTER_COUNT)
|
name = models.CharField(blank=False, max_length=JNF_TEXT_MAX_CHARACTER_COUNT)
|
||||||
|
changed_by = models.ForeignKey(User, blank=True, on_delete=models.RESTRICT, default=None, null=True)
|
||||||
|
history = HistoricalRecords(user_model=User)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _history_user(self):
|
||||||
|
return self.changed_by
|
||||||
|
|
||||||
|
@_history_user.setter
|
||||||
|
def _history_user(self, value):
|
||||||
|
if isinstance(value, User):
|
||||||
|
self.changed_by = value
|
||||||
|
else:
|
||||||
|
self.changed_by = None
|
||||||
|
|
||||||
|
|
||||||
def two_day_after_today():
|
def two_day_after_today():
|
||||||
|
@ -114,7 +143,8 @@ class Placement(models.Model):
|
||||||
deadline_datetime = models.DateTimeField(blank=False, verbose_name="Deadline Date", default=two_day_after_today)
|
deadline_datetime = models.DateTimeField(blank=False, verbose_name="Deadline Date", default=two_day_after_today)
|
||||||
created_at = models.DateTimeField(blank=False, default=None, null=True)
|
created_at = models.DateTimeField(blank=False, default=None, null=True)
|
||||||
updated_at = models.DateTimeField(blank=False, default=None, null=True)
|
updated_at = models.DateTimeField(blank=False, default=None, null=True)
|
||||||
|
changed_by = models.ForeignKey(User, on_delete=models.CASCADE, blank=True, null=True)
|
||||||
|
history = HistoricalRecords(user_model=User)
|
||||||
def format(self):
|
def format(self):
|
||||||
if self.company_name is not None:
|
if self.company_name is not None:
|
||||||
self.company_name = self.company_name.strip()[:JNF_SMALLTEXT_MAX_CHARACTER_COUNT]
|
self.company_name = self.company_name.strip()[:JNF_SMALLTEXT_MAX_CHARACTER_COUNT]
|
||||||
|
@ -158,6 +188,17 @@ class Placement(models.Model):
|
||||||
if self.additional_info is not None:
|
if self.additional_info is not None:
|
||||||
self.additional_info = [info.strip()[:JNF_TEXTMEDIUM_MAX_CHARACTER_COUNT] for info in list(self.additional_info)]
|
self.additional_info = [info.strip()[:JNF_TEXTMEDIUM_MAX_CHARACTER_COUNT] for info in list(self.additional_info)]
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _history_user(self):
|
||||||
|
return self.changed_by
|
||||||
|
|
||||||
|
@_history_user.setter
|
||||||
|
def _history_user(self, value):
|
||||||
|
if isinstance(value, User):
|
||||||
|
self.changed_by = value
|
||||||
|
else:
|
||||||
|
self.changed_by = None
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
''' On save, add timestamps '''
|
''' On save, add timestamps '''
|
||||||
if not self.created_at:
|
if not self.created_at:
|
||||||
|
@ -179,6 +220,8 @@ class PlacementApplication(models.Model):
|
||||||
selected = models.BooleanField(null=True, default=None, blank=True)
|
selected = models.BooleanField(null=True, default=None, blank=True)
|
||||||
applied_at = models.DateTimeField(blank=False, default=None, null=True)
|
applied_at = models.DateTimeField(blank=False, default=None, null=True)
|
||||||
updated_at = models.DateTimeField(blank=False, default=None, null=True)
|
updated_at = models.DateTimeField(blank=False, default=None, null=True)
|
||||||
|
changed_by = models.ForeignKey(User, blank=False, on_delete=models.RESTRICT, default=None, null=True)
|
||||||
|
history = HistoricalRecords(user_model=User)
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
''' On save, add timestamps '''
|
''' On save, add timestamps '''
|
||||||
|
@ -188,6 +231,17 @@ class PlacementApplication(models.Model):
|
||||||
|
|
||||||
return super(PlacementApplication, self).save(*args, **kwargs)
|
return super(PlacementApplication, self).save(*args, **kwargs)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _history_user(self):
|
||||||
|
return self.changed_by
|
||||||
|
|
||||||
|
@_history_user.setter
|
||||||
|
def _history_user(self, value):
|
||||||
|
if isinstance(value, User):
|
||||||
|
self.changed_by = value
|
||||||
|
else:
|
||||||
|
self.changed_by = None
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name_plural = "Placement Applications"
|
verbose_name_plural = "Placement Applications"
|
||||||
unique_together = ('placement_id', 'student_id')
|
unique_together = ('placement_id', 'student_id')
|
||||||
|
@ -206,3 +260,16 @@ class PrePlacementOffer(models.Model):
|
||||||
tier = models.CharField(blank=False, choices=TIERS, max_length=10)
|
tier = models.CharField(blank=False, choices=TIERS, max_length=10)
|
||||||
designation = models.CharField(blank=False, max_length=25, default=None, null=True)
|
designation = models.CharField(blank=False, max_length=25, default=None, null=True)
|
||||||
accepted = models.BooleanField(default=None, null=True)
|
accepted = models.BooleanField(default=None, null=True)
|
||||||
|
changed_by = models.ForeignKey(User, blank=False, on_delete=models.RESTRICT, default=None, null=True)
|
||||||
|
history = HistoricalRecords(user_model=User)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def _history_user(self):
|
||||||
|
return self.changed_by
|
||||||
|
|
||||||
|
@_history_user.setter
|
||||||
|
def _history_user(self, value):
|
||||||
|
if isinstance(value, User):
|
||||||
|
self.changed_by = value
|
||||||
|
else:
|
||||||
|
self.changed_by = None
|
||||||
|
|
|
@ -44,7 +44,7 @@ def addResume(request, id, email, user_type):
|
||||||
destination_path = STORAGE_DESTINATION_RESUMES + str(student.roll_no) + "/"
|
destination_path = STORAGE_DESTINATION_RESUMES + str(student.roll_no) + "/"
|
||||||
file_name = saveFile(file, destination_path)
|
file_name = saveFile(file, destination_path)
|
||||||
student.resumes.append(file_name)
|
student.resumes.append(file_name)
|
||||||
|
student.changed_by = get_object_or_404(User, id=id)
|
||||||
student.save()
|
student.save()
|
||||||
return Response({'action': "Upload Resume", 'message': "Resume Added"},
|
return Response({'action': "Upload Resume", 'message': "Resume Added"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
@ -102,8 +102,9 @@ def deleteResume(request, id, email, user_type):
|
||||||
|
|
||||||
destination_path = STORAGE_DESTINATION_RESUMES + id + "/" + str(file_name)
|
destination_path = STORAGE_DESTINATION_RESUMES + id + "/" + str(file_name)
|
||||||
if path.exists(destination_path):
|
if path.exists(destination_path):
|
||||||
remove(destination_path)
|
# remove(destination_path)
|
||||||
student.resumes.remove(file_name)
|
student.resumes.remove(file_name)
|
||||||
|
student.changed_by = get_object_or_404(User, id=id)
|
||||||
student.save()
|
student.save()
|
||||||
return Response({'action': "Delete Resume", 'message': "Resume Deleted"},
|
return Response({'action': "Delete Resume", 'message': "Resume Deleted"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
@ -177,7 +178,7 @@ def submitApplication(request, id, email, user_type):
|
||||||
}
|
}
|
||||||
subject = STUDENT_APPLICATION_SUBMITTED_TEMPLATE_SUBJECT.format(company_name=opening.company_name)
|
subject = STUDENT_APPLICATION_SUBMITTED_TEMPLATE_SUBJECT.format(company_name=opening.company_name)
|
||||||
sendEmail(email, subject, data, STUDENT_APPLICATION_SUBMITTED_TEMPLATE)
|
sendEmail(email, subject, data, STUDENT_APPLICATION_SUBMITTED_TEMPLATE)
|
||||||
|
application.changed_by = get_object_or_404(User, id=id)
|
||||||
application.save()
|
application.save()
|
||||||
return Response({'action': "Submit Application", 'message': "Application Submitted"},
|
return Response({'action': "Submit Application", 'message': "Application Submitted"},
|
||||||
status=status.HTTP_200_OK)
|
status=status.HTTP_200_OK)
|
||||||
|
|
|
@ -29,7 +29,7 @@ SECRET_KEY = 'e_i2g3z!y4+p3dwm%k9k=zmsot@aya-0$mmetgxz4mp#8_oy#*'
|
||||||
# SECURITY WARNING: don't run with debug turned on in production!
|
# SECURITY WARNING: don't run with debug turned on in production!
|
||||||
DEBUG = True
|
DEBUG = True
|
||||||
|
|
||||||
ALLOWED_HOSTS = ['cdc-iitdh.herokuapp.com/', 'localhost', '192.168.29.199']
|
ALLOWED_HOSTS = ['cdc-iitdh.herokuapp.com/', 'localhost', '192.168.29.199', '127.0.0.1']
|
||||||
|
|
||||||
# Application definition
|
# Application definition
|
||||||
|
|
||||||
|
@ -44,7 +44,8 @@ INSTALLED_APPS = [
|
||||||
'rest_framework',
|
'rest_framework',
|
||||||
'corsheaders',
|
'corsheaders',
|
||||||
'django_db_logger',
|
'django_db_logger',
|
||||||
'background_task'
|
'background_task',
|
||||||
|
'simple_history',
|
||||||
]
|
]
|
||||||
|
|
||||||
MIDDLEWARE = [
|
MIDDLEWARE = [
|
||||||
|
@ -57,7 +58,7 @@ MIDDLEWARE = [
|
||||||
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
||||||
'django.contrib.messages.middleware.MessageMiddleware',
|
'django.contrib.messages.middleware.MessageMiddleware',
|
||||||
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||||
|
'simple_history.middleware.HistoryRequestMiddleware',
|
||||||
]
|
]
|
||||||
|
|
||||||
ROOT_URLCONF = 'CDC_Backend.urls'
|
ROOT_URLCONF = 'CDC_Backend.urls'
|
||||||
|
|
|
@ -15,6 +15,11 @@
|
||||||
4. [**api/admin/updateOfferAccepted**](#apiadminupdateofferaccepted)
|
4. [**api/admin/updateOfferAccepted**](#apiadminupdateofferaccepted)
|
||||||
5. [**api/admin/updateEmailVerified**](#apiadminupdateemailverified)
|
5. [**api/admin/updateEmailVerified**](#apiadminupdateemailverified)
|
||||||
6. [**api/admin/updateAdditionalInfo**](#apiadminupdateadditionalinfo)
|
6. [**api/admin/updateAdditionalInfo**](#apiadminupdateadditionalinfo)
|
||||||
|
7. [**api/admin/getApplications**](#apiadmingetApplications)
|
||||||
|
8. [**api/admin/submitApplication**](#apiadminsubmitApplication)
|
||||||
|
9. [**api/admin/generateCSV**](#apiadmingeneratecsv)
|
||||||
|
10. [**api/admin/addPPO**](#apiadminaddppo)
|
||||||
|
11. [**api/admin/getStudentApplication**](#apiadmingetstudentapplication)
|
||||||
4. [**Company APIs**](#company-portal-apis)
|
4. [**Company APIs**](#company-portal-apis)
|
||||||
1. [**api/company/addPlacement/**](#apicompanyaddplacement)
|
1. [**api/company/addPlacement/**](#apicompanyaddplacement)
|
||||||
5. [**Common Errors**](#common-errors)
|
5. [**Common Errors**](#common-errors)
|
||||||
|
@ -47,9 +52,7 @@ Response is a Json with these fields
|
||||||
{
|
{
|
||||||
"action": "Login",
|
"action": "Login",
|
||||||
"message": "Verified",
|
"message": "Verified",
|
||||||
"user_type": [
|
"user_type": ["student"]
|
||||||
"student"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -131,7 +134,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ---------------------- |
|
||||||
| 200 OK | `Details Found` |
|
| 200 OK | `Details Found` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
@ -240,20 +243,11 @@ Response is a Json with these fields
|
||||||
"is_selection_procedure_details_pdf": true,
|
"is_selection_procedure_details_pdf": true,
|
||||||
"tier": "4",
|
"tier": "4",
|
||||||
"tentative_date_of_joining": "2022-01-15",
|
"tentative_date_of_joining": "2022-01-15",
|
||||||
"allowed_batch": [
|
"allowed_batch": ["2018", "2019"],
|
||||||
"2018",
|
"allowed_branch": ["CSE", "EE"],
|
||||||
"2019"
|
|
||||||
],
|
|
||||||
"allowed_branch": [
|
|
||||||
"CSE",
|
|
||||||
"EE"
|
|
||||||
],
|
|
||||||
"tentative_no_of_offers": 5,
|
"tentative_no_of_offers": 5,
|
||||||
"other_requirements": "above 8 cpi",
|
"other_requirements": "above 8 cpi",
|
||||||
"additional_info": [
|
"additional_info": ["School", "Home Town"],
|
||||||
"School",
|
|
||||||
"Home Town"
|
|
||||||
],
|
|
||||||
"deadline_date": "2021-12-04",
|
"deadline_date": "2021-12-04",
|
||||||
"created_at": "2021-12-02T20:12:21+05:30"
|
"created_at": "2021-12-02T20:12:21+05:30"
|
||||||
}
|
}
|
||||||
|
@ -334,20 +328,11 @@ Response is a Json with these fields
|
||||||
"is_selection_procedure_details_pdf": true,
|
"is_selection_procedure_details_pdf": true,
|
||||||
"tier": "4",
|
"tier": "4",
|
||||||
"tentative_date_of_joining": "2022-01-15",
|
"tentative_date_of_joining": "2022-01-15",
|
||||||
"allowed_batch": [
|
"allowed_batch": ["2018", "2019"],
|
||||||
"2018",
|
"allowed_branch": ["CSE", "EE"],
|
||||||
"2019"
|
|
||||||
],
|
|
||||||
"allowed_branch": [
|
|
||||||
"CSE",
|
|
||||||
"EE"
|
|
||||||
],
|
|
||||||
"tentative_no_of_offers": 5,
|
"tentative_no_of_offers": 5,
|
||||||
"other_requirements": "above 8 cpi",
|
"other_requirements": "above 8 cpi",
|
||||||
"additional_info": [
|
"additional_info": ["School", "Home Town"],
|
||||||
"School",
|
|
||||||
"Home Town"
|
|
||||||
],
|
|
||||||
"deadline_date": "2021-12-04",
|
"deadline_date": "2021-12-04",
|
||||||
"created_at": "2021-12-02T20:12:21+05:30"
|
"created_at": "2021-12-02T20:12:21+05:30"
|
||||||
},
|
},
|
||||||
|
@ -370,7 +355,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ---------------------- |
|
||||||
| 200 OK | `Data Found` |
|
| 200 OK | `Data Found` |
|
||||||
| 404 Not Found | `Student Not Found` |
|
| 404 Not Found | `Student Not Found` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
@ -553,12 +538,12 @@ Request_Body:
|
||||||
"opening_id": "Q54IRZZMC3RP8F6",
|
"opening_id": "Q54IRZZMC3RP8F6",
|
||||||
"student_list": [
|
"student_list": [
|
||||||
{
|
{
|
||||||
"student_id":"190010036",
|
"student_id": "190010036",
|
||||||
"student_selected":"true"
|
"student_selected": "true"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"student_id":"190050022",
|
"student_id": "190050022",
|
||||||
"student_selected":"false"
|
"student_selected": "false"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -586,7 +571,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ---------------------- |
|
||||||
| 200 OK | `Marked Status` |
|
| 200 OK | `Marked Status` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
@ -619,6 +604,94 @@ Response is a Json with these fields
|
||||||
{
|
{
|
||||||
"action": "Get Dashboard - Admin",
|
"action": "Get Dashboard - Admin",
|
||||||
"message": "Data Found",
|
"message": "Data Found",
|
||||||
|
"new": [
|
||||||
|
{
|
||||||
|
"id": "Z54IRZZMB3RP9TR",
|
||||||
|
"company_details_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FI5U4RDTV0OP0EM0_2019+Student+Details+-+Total%28State+Sort%29+-+Copy.pdf",
|
||||||
|
"name": "I5U4RDTV0OP0EM0_2019 Student Details - Total(State Sort) - Copy.pdf"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FW04JWWNNMIBX0JX_2019+Student+Details+-+Total%28State+Sort%29.pdf",
|
||||||
|
"name": "W04JWWNNMIBX0JX_2019 Student Details - Total(State Sort).pdf"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FT1BXP98WBT9BHOR_AP0313017732021LL-Driving+Licence+-+Copy.pdf",
|
||||||
|
"name": "T1BXP98WBT9BHOR_AP0313017732021LL-Driving Licence - Copy.pdf"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FC78TE2Z67BPZ41O_CSE-V-SEM.pdf",
|
||||||
|
"name": "C78TE2Z67BPZ41O_CSE-V-SEM.pdf"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"compensation_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2F8D5OFQ46H43DD3S_module5And6Attendance.pdf",
|
||||||
|
"name": "8D5OFQ46H43DD3S_module5And6Attendance.pdf"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FG8OU2PE919PFKSR_Print+Application11.pdf",
|
||||||
|
"name": "G8OU2PE919PFKSR_Print Application11.pdf"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"selection_procedure_details_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FDZTQQ6YBGBQ47PY_screencapture-onlinesbi-sbi-sbicollect-fsssuccessresponseredirect-htm-2021-07-19-18_",
|
||||||
|
"name": "DZTQQ6YBGBQ47PY_screencapture-onlinesbi-sbi-sbicollect-fsssuccessresponseredirect-htm-2021-07-19-18_"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FN490PUXJEEN4JZ9_screencapture-onlinesbi-sbi-sbicollect-payment-suvidhapayment-htm-2021-07-19-23_12_3",
|
||||||
|
"name": "N490PUXJEEN4JZ9_screencapture-onlinesbi-sbi-sbicollect-payment-suvidhapayment-htm-2021-07-19-23_12_3"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"company_name": "Cred",
|
||||||
|
"address": "Cred India Pvt. Ltd.5, Awagarh House, MG Road(next to Bachoomal collections)Agra (UP), - 282002India",
|
||||||
|
"company_type": "Private Sector",
|
||||||
|
"nature_of_business": "Technology",
|
||||||
|
"website": "www.cred.com",
|
||||||
|
"company_details": "This s a very nice company",
|
||||||
|
"is_company_details_pdf": true,
|
||||||
|
"contact_person_name": "John",
|
||||||
|
"phone_number": 9390291922,
|
||||||
|
"email": "@gmail.com",
|
||||||
|
"city": "Mumbai",
|
||||||
|
"state": "Maharashtra",
|
||||||
|
"country": "India",
|
||||||
|
"pin_code": 530013,
|
||||||
|
"city_type": "Domestic",
|
||||||
|
"designation": "Software Developer",
|
||||||
|
"description": "very nice job",
|
||||||
|
"is_description_pdf": true,
|
||||||
|
"compensation_CTC": 1200000,
|
||||||
|
"compensation_gross": 1100000,
|
||||||
|
"compensation_take_home": 1000000,
|
||||||
|
"compensation_bonus": 10000,
|
||||||
|
"compensation_details": "very good compensation",
|
||||||
|
"is_compensation_details_pdf": true,
|
||||||
|
"bond_details": "nil",
|
||||||
|
"selection_procedure_rounds": [
|
||||||
|
"Resume Shortlisting",
|
||||||
|
"Technical Interview",
|
||||||
|
"HR Interview"
|
||||||
|
],
|
||||||
|
"selection_procedure_details": "All rounds are complusory",
|
||||||
|
"is_selection_procedure_details_pdf": true,
|
||||||
|
"tier": "4",
|
||||||
|
"tentative_date_of_joining": "2022-01-15",
|
||||||
|
"allowed_batch": ["2018", "2019"],
|
||||||
|
"allowed_branch": ["CSE", "EE"],
|
||||||
|
"tentative_no_of_offers": 5,
|
||||||
|
"other_requirements": "above 8 cpi",
|
||||||
|
"additional_info": ["School", "Home Town"],
|
||||||
|
"email_verified": false,
|
||||||
|
"offer_accepted": null,
|
||||||
|
"deadline_date": "2021-12-04",
|
||||||
|
"created_at": "2021-12-02T20:12:21+05:30"
|
||||||
|
}
|
||||||
|
],
|
||||||
"ongoing": [
|
"ongoing": [
|
||||||
{
|
{
|
||||||
"id": "Q54IRZZMC3RP8F6",
|
"id": "Q54IRZZMC3RP8F6",
|
||||||
|
@ -696,27 +769,105 @@ Response is a Json with these fields
|
||||||
"is_selection_procedure_details_pdf": true,
|
"is_selection_procedure_details_pdf": true,
|
||||||
"tier": "4",
|
"tier": "4",
|
||||||
"tentative_date_of_joining": "2022-01-15",
|
"tentative_date_of_joining": "2022-01-15",
|
||||||
"allowed_batch": [
|
"allowed_batch": ["2018", "2019"],
|
||||||
"2018",
|
"allowed_branch": ["CSE", "EE"],
|
||||||
"2019"
|
|
||||||
],
|
|
||||||
"allowed_branch": [
|
|
||||||
"CSE",
|
|
||||||
"EE"
|
|
||||||
],
|
|
||||||
"tentative_no_of_offers": 5,
|
"tentative_no_of_offers": 5,
|
||||||
"other_requirements": "above 8 cpi",
|
"other_requirements": "above 8 cpi",
|
||||||
"additional_info": [
|
"additional_info": ["School", "Home Town"],
|
||||||
"School",
|
|
||||||
"Home Town"
|
|
||||||
],
|
|
||||||
"email_verified": false,
|
"email_verified": false,
|
||||||
"offer_accepted": null,
|
"offer_accepted": null,
|
||||||
"deadline_date": "2021-12-04",
|
"deadline_date": "2021-12-04",
|
||||||
"created_at": "2021-12-02T20:12:21+05:30"
|
"created_at": "2021-12-02T20:12:21+05:30"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"previous": []
|
"previous": [
|
||||||
|
{
|
||||||
|
"id": "Q74IRZZMC3RP8F6",
|
||||||
|
"company_details_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FI5U4RDTV0OP0EM0_2019+Student+Details+-+Total%28State+Sort%29+-+Copy.pdf",
|
||||||
|
"name": "I5U4RDTV0OP0EM0_2019 Student Details - Total(State Sort) - Copy.pdf"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FW04JWWNNMIBX0JX_2019+Student+Details+-+Total%28State+Sort%29.pdf",
|
||||||
|
"name": "W04JWWNNMIBX0JX_2019 Student Details - Total(State Sort).pdf"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FT1BXP98WBT9BHOR_AP0313017732021LL-Driving+Licence+-+Copy.pdf",
|
||||||
|
"name": "T1BXP98WBT9BHOR_AP0313017732021LL-Driving Licence - Copy.pdf"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FC78TE2Z67BPZ41O_CSE-V-SEM.pdf",
|
||||||
|
"name": "C78TE2Z67BPZ41O_CSE-V-SEM.pdf"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"compensation_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2F8D5OFQ46H43DD3S_module5And6Attendance.pdf",
|
||||||
|
"name": "8D5OFQ46H43DD3S_module5And6Attendance.pdf"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FG8OU2PE919PFKSR_Print+Application11.pdf",
|
||||||
|
"name": "G8OU2PE919PFKSR_Print Application11.pdf"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"selection_procedure_details_pdf_links": [
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FDZTQQ6YBGBQ47PY_screencapture-onlinesbi-sbi-sbicollect-fsssuccessresponseredirect-htm-2021-07-19-18_",
|
||||||
|
"name": "DZTQQ6YBGBQ47PY_screencapture-onlinesbi-sbi-sbicollect-fsssuccessresponseredirect-htm-2021-07-19-18_"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"link": "https://storage.googleapis.com/cdc-backend-attachments/company_attachments/Q54IRZZMC3RP8F6%2FN490PUXJEEN4JZ9_screencapture-onlinesbi-sbi-sbicollect-payment-suvidhapayment-htm-2021-07-19-23_12_3",
|
||||||
|
"name": "N490PUXJEEN4JZ9_screencapture-onlinesbi-sbi-sbicollect-payment-suvidhapayment-htm-2021-07-19-23_12_3"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"company_name": "Make My Trip",
|
||||||
|
"address": "MakeMyTrip India Pvt. Ltd.5, Awagarh House, MG Road(next to Bachoomal collections)Agra (UP), - 282002India",
|
||||||
|
"company_type": "Private Sector",
|
||||||
|
"nature_of_business": "Technology",
|
||||||
|
"website": "www.makemytrip.com",
|
||||||
|
"company_details": "This s a very nice company",
|
||||||
|
"is_company_details_pdf": true,
|
||||||
|
"contact_person_name": "Gowtham",
|
||||||
|
"phone_number": 9390291911,
|
||||||
|
"email": "saisurya3127@gmail.com",
|
||||||
|
"city": "Mumbai",
|
||||||
|
"state": "Maharashtra",
|
||||||
|
"country": "India",
|
||||||
|
"pin_code": 530013,
|
||||||
|
"city_type": "Domestic",
|
||||||
|
"designation": "Software Developer",
|
||||||
|
"description": "very nice job",
|
||||||
|
"is_description_pdf": true,
|
||||||
|
"compensation_CTC": 1200000,
|
||||||
|
"compensation_gross": 1100000,
|
||||||
|
"compensation_take_home": 1000000,
|
||||||
|
"compensation_bonus": 10000,
|
||||||
|
"compensation_details": "very good compensation",
|
||||||
|
"is_compensation_details_pdf": true,
|
||||||
|
"bond_details": "nil",
|
||||||
|
"selection_procedure_rounds": [
|
||||||
|
"Resume Shortlisting",
|
||||||
|
"Technical Interview",
|
||||||
|
"HR Interview"
|
||||||
|
],
|
||||||
|
"selection_procedure_details": "All rounds are complusory",
|
||||||
|
"is_selection_procedure_details_pdf": true,
|
||||||
|
"tier": "4",
|
||||||
|
"tentative_date_of_joining": "2022-01-15",
|
||||||
|
"allowed_batch": ["2018", "2019"],
|
||||||
|
"allowed_branch": ["CSE", "EE"],
|
||||||
|
"tentative_no_of_offers": 5,
|
||||||
|
"other_requirements": "above 8 cpi",
|
||||||
|
"additional_info": ["School", "Home Town"],
|
||||||
|
"email_verified": false,
|
||||||
|
"offer_accepted": null,
|
||||||
|
"deadline_date": "2021-12-04",
|
||||||
|
"created_at": "2021-12-02T20:12:21+05:30"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -724,13 +875,14 @@ Response is a Json with these fields
|
||||||
- message: Tells us what happened with our Request.
|
- message: Tells us what happened with our Request.
|
||||||
- ongoing: Gives us the list of placements that are accepting applications.
|
- ongoing: Gives us the list of placements that are accepting applications.
|
||||||
- previous: Gives us the list of placements that stopped accepting applications.
|
- previous: Gives us the list of placements that stopped accepting applications.
|
||||||
|
- new : Gives us the list of placements that is not yet accepeted by CDC.
|
||||||
|
|
||||||
### Status Codes
|
### Status Codes
|
||||||
|
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ---------------------- |
|
||||||
| 200 OK | `Data Found` |
|
| 200 OK | `Data Found` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
@ -776,7 +928,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ---------------------- |
|
||||||
| 200 OK | `Deadline Updated` |
|
| 200 OK | `Deadline Updated` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
@ -822,7 +974,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ----------------------- |
|
||||||
| 200 OK | `Update Offer Accepted` |
|
| 200 OK | `Update Offer Accepted` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
@ -888,11 +1040,7 @@ Request_Body:
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"opening_id": "Q54IRZZMC3RP8F6",
|
"opening_id": "Q54IRZZMC3RP8F6",
|
||||||
"additional_info": [
|
"additional_info": ["School", "Place of Living", "Research Interests"]
|
||||||
"School",
|
|
||||||
"Place of Living",
|
|
||||||
"Research Interests"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -918,7 +1066,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| --------------- | ------------------------ |
|
| --------------- | ------------------------- |
|
||||||
| 200 OK | `Additional Info Updated` |
|
| 200 OK | `Additional Info Updated` |
|
||||||
| 400 BAD_REQUEST | `Something Went Wrong` |
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
@ -926,6 +1074,294 @@ You may see some different errors which can be seen [here](#common-errors)
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
<!-- new branch -->
|
||||||
|
|
||||||
|
## `api/admin/getApplications`
|
||||||
|
|
||||||
|
This api is used to fetch all the applications applied by students for all placements
|
||||||
|
|
||||||
|
### How to Use?
|
||||||
|
|
||||||
|
Send a `POST` request to `api/admin/getApplications`<br>
|
||||||
|
Request_Body:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"opening_id": "Q54IRZZMC3RP8F6"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Headers <br>
|
||||||
|
> Authorization: "Bearer {tokenID}"
|
||||||
|
|
||||||
|
### Response
|
||||||
|
|
||||||
|
Response is a Json with these fields
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"action": "Get Applications",
|
||||||
|
"message": "Data Found",
|
||||||
|
"applications": [
|
||||||
|
{
|
||||||
|
"id": "200010021",
|
||||||
|
"student_details": {
|
||||||
|
"id": "200010021",
|
||||||
|
"resume_list": [
|
||||||
|
{
|
||||||
|
"link": "http://localhost/storage/Resumes/200010021/resume_link",
|
||||||
|
"name": "resume_link"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"offers": [
|
||||||
|
{
|
||||||
|
"designation": "sde",
|
||||||
|
"company_name": "JP Morgan",
|
||||||
|
"application_id": "200010021",
|
||||||
|
"placement_offer_type": "Normal"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"roll_no": 200010021,
|
||||||
|
"name": "John",
|
||||||
|
"batch": "2020",
|
||||||
|
"branch": "CSE",
|
||||||
|
"phone_number": 8105699450,
|
||||||
|
"cpi": "9.00",
|
||||||
|
"can_apply": true
|
||||||
|
},
|
||||||
|
"resume_link": {
|
||||||
|
"link": "http://localhost/storage/Resumes/200010021/resume_links",
|
||||||
|
"name": "resume_links"
|
||||||
|
},
|
||||||
|
"additional_info": null,
|
||||||
|
"selected": true,
|
||||||
|
"applied_at": "2022-05-30T19:15:33+05:30",
|
||||||
|
"updated_at": "2022-05-30T19:16:31.662929+05:30",
|
||||||
|
"student": "200010021"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
- action: Tells us about the message creator<Br>
|
||||||
|
- message: Tells us what happened with our Request.
|
||||||
|
|
||||||
|
### Status Codes
|
||||||
|
|
||||||
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
|
| Status Codes | Possible Messages |
|
||||||
|
| --------------- | ---------------------- |
|
||||||
|
| 200 OK | `Data Found` |
|
||||||
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
You may see some different errors which can be seen [here](#common-errors)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## `api/admin/submitApplication`
|
||||||
|
|
||||||
|
This api is used to submit a students application
|
||||||
|
|
||||||
|
Request_Body:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"applications_id": "F28IRGGMC3RP8Y8",
|
||||||
|
"student_id": "200010022",
|
||||||
|
"opening_id": "Q54IRZZMC3RP8F6",
|
||||||
|
"additional_info": {
|
||||||
|
"School": "Lions International",
|
||||||
|
"City": "Banglore"
|
||||||
|
},
|
||||||
|
"resume_file_name": "8KIOT3PW1JIS718_CSE-V-SEM.pdf"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Headers <br>
|
||||||
|
> Authorization: "Bearer {tokenID}"
|
||||||
|
|
||||||
|
### Response
|
||||||
|
|
||||||
|
Response is a Json with these fields
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"action": "Add Student Application",
|
||||||
|
"message": "Application Added"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Status Codes
|
||||||
|
|
||||||
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
|
| Status Codes | Possible Messages |
|
||||||
|
| --------------- | ---------------------- |
|
||||||
|
| 200 OK | `Application Added` |
|
||||||
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
You may see some different errors which can be seen [here](#common-errors)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## `api/admin/generateCSV`
|
||||||
|
|
||||||
|
This api is used to generate a CSV file that contains sequential details of all the applications
|
||||||
|
|
||||||
|
Request_Body:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"opening_id": "Q54IRZZMC3RP8F6"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Headers <br>
|
||||||
|
> Authorization: "Bearer {tokenID}"
|
||||||
|
|
||||||
|
### Response
|
||||||
|
|
||||||
|
Response is a Json with these fields
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"action": "Create CSV",
|
||||||
|
"message": "CSV Created",
|
||||||
|
"file": "csv_file_link"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Status Codes
|
||||||
|
|
||||||
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
|
| Status Codes | Possible Messages |
|
||||||
|
| --------------- | ---------------------- |
|
||||||
|
| 200 OK | `CSV created` |
|
||||||
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
You may see some different errors which can be seen [here](#common-errors)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## `api/admin/addPPO`
|
||||||
|
|
||||||
|
This api is used to add a PPO for a student in the corresponding company
|
||||||
|
|
||||||
|
Request_Body:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"company_name": "Geeks for Geeks",
|
||||||
|
"compensation_gross": "1000000",
|
||||||
|
"offer_accepted": "true",
|
||||||
|
"student_id": "200010022",
|
||||||
|
"designation": "Technical Content Writer",
|
||||||
|
"tier": "4"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Response
|
||||||
|
|
||||||
|
Response is a Json with these fields
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"action": "Add PPO",
|
||||||
|
"message": "PPO Added"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Status Codes
|
||||||
|
|
||||||
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
|
| Status Codes | Possible Messages |
|
||||||
|
| --------------- | ---------------------- |
|
||||||
|
| 200 OK | `PPO Added` |
|
||||||
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
|
||||||
|
You may see some different errors which can be seen [here](#common-errors)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## `api/admin/getStudentApplication`
|
||||||
|
|
||||||
|
This api is used to fetch the application details of the required student
|
||||||
|
|
||||||
|
Request_Body:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"student_id": "200010022",
|
||||||
|
"opening_id": "Q54IRZZMC3RP8F6"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Headers <br>
|
||||||
|
> Authorization: "Bearer {tokenID}"
|
||||||
|
|
||||||
|
### Response
|
||||||
|
|
||||||
|
Response is a Json with these fields when the application is found.
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"action": "Get Student Application",
|
||||||
|
"application_found": "true",
|
||||||
|
"application_info": {
|
||||||
|
"id": "F28IRGGMC3RP8Y8",
|
||||||
|
"additional_info": {
|
||||||
|
"12th grade": "9.1",
|
||||||
|
"current GPA": "9.6"
|
||||||
|
},
|
||||||
|
"resume": "resume_link"
|
||||||
|
},
|
||||||
|
"student_details": {
|
||||||
|
"name": "John",
|
||||||
|
"batch": "2020",
|
||||||
|
"branch": "MMAE",
|
||||||
|
"resume_list": {
|
||||||
|
"link": "http://localhost/storage/Resumes/200010021/resume_links",
|
||||||
|
"name": "resume_link"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Response is a Json with these fields when the applciation is not found.
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"action": "Get Student Application",
|
||||||
|
"application_found": "false",
|
||||||
|
"student_details": {
|
||||||
|
"name": "John",
|
||||||
|
"batch": "2020",
|
||||||
|
"branch": "MMAE",
|
||||||
|
"resume_list": {
|
||||||
|
"link": "http://localhost/storage/Resumes/200010021/resume_links",
|
||||||
|
"name": "resume_link"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Status Codes
|
||||||
|
|
||||||
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
|
| Status Codes | Possible Messages |
|
||||||
|
| --------------- | ----------------------- |
|
||||||
|
| 200 OK | `` |
|
||||||
|
| 400 BAD_REQUEST | `Something Went Wrong` |
|
||||||
|
| 404 NOT_FOUND | `Application not found` |
|
||||||
|
|
||||||
|
You may see some different errors which can be seen [here](#common-errors)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
# Company Portal APIs
|
# Company Portal APIs
|
||||||
|
|
||||||
## `api/company/addPlacement/`
|
## `api/company/addPlacement/`
|
||||||
|
@ -940,113 +1376,45 @@ Request_Body:
|
||||||
|
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"company_name": [
|
"company_name": ["Make My Trip"],
|
||||||
"Make My Trip"
|
|
||||||
],
|
|
||||||
"address": [
|
"address": [
|
||||||
"MakeMyTrip India Pvt. Ltd.\n5, Awagarh House, MG Road\n(next to Bachoomal collections)\nAgra (UP), - 282002\nIndia"
|
"MakeMyTrip India Pvt. Ltd.\n5, Awagarh House, MG Road\n(next to Bachoomal collections)\nAgra (UP), - 282002\nIndia"
|
||||||
],
|
],
|
||||||
"company_type": [
|
"company_type": ["Private Sector"],
|
||||||
"Private Sector"
|
"nature_of_business": ["Technology"],
|
||||||
],
|
"website": ["www.makemytrip.com"],
|
||||||
"nature_of_business": [
|
"company_details": ["This s a very nice company"],
|
||||||
"Technology"
|
"is_company_details_pdf": ["true"],
|
||||||
],
|
"contact_person_name": ["Gowtham"],
|
||||||
"website": [
|
"phone_number": ["9390291911"],
|
||||||
"www.makemytrip.com"
|
"email": ["saisurya3127@gmail.com"],
|
||||||
],
|
"city": ["Mumbai"],
|
||||||
"company_details": [
|
"state": ["Maharashtra"],
|
||||||
"This s a very nice company"
|
"country": ["India"],
|
||||||
],
|
"pincode": ["530013"],
|
||||||
"is_company_details_pdf": [
|
"designation": ["Software Developer"],
|
||||||
"true"
|
"description": ["very nice job"],
|
||||||
],
|
"is_description_pdf": ["true"],
|
||||||
"contact_person_name": [
|
"compensation_ctc": ["1200000"],
|
||||||
"Gowtham"
|
"compensation_gross": ["1100000"],
|
||||||
],
|
"compensation_take_home": ["1000000"],
|
||||||
"phone_number": [
|
"compensation_bonus": ["10000"],
|
||||||
"9390291911"
|
"compensation_details": ["very good compensation"],
|
||||||
],
|
"is_compensation_details_pdf": ["true"],
|
||||||
"email": [
|
"bond_details": ["nil"],
|
||||||
"saisurya3127@gmail.com"
|
|
||||||
],
|
|
||||||
"city": [
|
|
||||||
"Mumbai"
|
|
||||||
],
|
|
||||||
"state": [
|
|
||||||
"Maharashtra"
|
|
||||||
],
|
|
||||||
"country": [
|
|
||||||
"India"
|
|
||||||
],
|
|
||||||
"pincode": [
|
|
||||||
"530013"
|
|
||||||
],
|
|
||||||
"designation": [
|
|
||||||
"Software Developer"
|
|
||||||
],
|
|
||||||
"description": [
|
|
||||||
"very nice job"
|
|
||||||
],
|
|
||||||
"is_description_pdf": [
|
|
||||||
"true"
|
|
||||||
],
|
|
||||||
"compensation_ctc": [
|
|
||||||
"1200000"
|
|
||||||
],
|
|
||||||
"compensation_gross": [
|
|
||||||
"1100000"
|
|
||||||
],
|
|
||||||
"compensation_take_home": [
|
|
||||||
"1000000"
|
|
||||||
],
|
|
||||||
"compensation_bonus": [
|
|
||||||
"10000"
|
|
||||||
],
|
|
||||||
"compensation_details": [
|
|
||||||
"very good compensation"
|
|
||||||
],
|
|
||||||
"is_compensation_details_pdf": [
|
|
||||||
"true"
|
|
||||||
],
|
|
||||||
"bond_details": [
|
|
||||||
"nil"
|
|
||||||
],
|
|
||||||
"selection_procedure_rounds": [
|
"selection_procedure_rounds": [
|
||||||
"['Resume Shortlisting', 'Technical Interview', 'HR Interview']"
|
"['Resume Shortlisting', 'Technical Interview', 'HR Interview']"
|
||||||
],
|
],
|
||||||
"selection_procedure_details": [
|
"selection_procedure_details": ["All rounds are complusory"],
|
||||||
"All rounds are complusory"
|
"is_selection_procedure_details_pdf": ["true"],
|
||||||
],
|
"tentative_date_of_joining": ["15-01-2022"],
|
||||||
"is_selection_procedure_details_pdf": [
|
"allowed_branch": ["['CSE', 'EE']"],
|
||||||
"true"
|
"tentative_no_of_offers": ["5"],
|
||||||
],
|
"other_requirements": ["above 8 cpi"],
|
||||||
"tentative_date_of_joining": [
|
"company_details_pdf": ["__FILE_OBJECT__", "__FILE_OBJECT__"],
|
||||||
"15-01-2022"
|
"description_pdf": ["__FILE_OBJECT__"],
|
||||||
],
|
"compensation_details_pdf": ["__FILE_OBJECT__"],
|
||||||
"allowed_branch": [
|
"selection_procedure_details_pdf": ["__FILE_OBJECT__", "__FILE_OBJECT__"]
|
||||||
"['CSE', 'EE']"
|
|
||||||
],
|
|
||||||
"tentative_no_of_offers": [
|
|
||||||
"5"
|
|
||||||
],
|
|
||||||
"other_requirements": [
|
|
||||||
"above 8 cpi"
|
|
||||||
],
|
|
||||||
"company_details_pdf": [
|
|
||||||
"__FILE_OBJECT__",
|
|
||||||
"__FILE_OBJECT__"
|
|
||||||
],
|
|
||||||
"description_pdf": [
|
|
||||||
"__FILE_OBJECT__"
|
|
||||||
],
|
|
||||||
"compensation_details_pdf": [
|
|
||||||
"__FILE_OBJECT__"
|
|
||||||
],
|
|
||||||
"selection_procedure_details_pdf": [
|
|
||||||
"__FILE_OBJECT__",
|
|
||||||
"__FILE_OBJECT__"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -1072,7 +1440,7 @@ Response is a Json with these fields
|
||||||
The possible responses for this api request are as follows
|
The possible responses for this api request are as follows
|
||||||
|
|
||||||
| Status Codes | Possible Messages |
|
| Status Codes | Possible Messages |
|
||||||
| ------------- | ----------------- |
|
| ------------- | ------------------------------ |
|
||||||
| 200 OK | `Placement Added Successfully` |
|
| 200 OK | `Placement Added Successfully` |
|
||||||
| 404 NOT FOUND | `Something went wrong` |
|
| 404 NOT FOUND | `Something went wrong` |
|
||||||
|
|
||||||
|
@ -1092,7 +1460,3 @@ Some common errors that you may see while accessing the Apis
|
||||||
| 404 NOT FOUND | `User Not Found. Contact CDC for more details` | You may not be a user at CDC, IIT Dharwad. Please contact us to get your user account |
|
| 404 NOT FOUND | `User Not Found. Contact CDC for more details` | You may not be a user at CDC, IIT Dharwad. Please contact us to get your user account |
|
||||||
| 400 BAD_REQUEST | `Error Occurred` | Any random Error which can be seen in the {error} string. |
|
| 400 BAD_REQUEST | `Error Occurred` | Any random Error which can be seen in the {error} string. |
|
||||||
| 400 BAD_REQUEST | `Something went wrong` | Any random Error which can be seen in the {error} string. |
|
| 400 BAD_REQUEST | `Something went wrong` | Any random Error which can be seen in the {error} string. |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -5,12 +5,14 @@ certifi==2021.10.8
|
||||||
chardet==4.0.0
|
chardet==4.0.0
|
||||||
charset-normalizer==2.0.12
|
charset-normalizer==2.0.12
|
||||||
colorama==0.4.4
|
colorama==0.4.4
|
||||||
|
dill==0.3.5.1
|
||||||
dj-database-url==0.5.0
|
dj-database-url==0.5.0
|
||||||
Django==3.2.13
|
Django==3.2.13
|
||||||
django-background-tasks==1.2.5
|
django-background-tasks==1.2.5
|
||||||
django-compat==1.0.15
|
django-compat==1.0.15
|
||||||
django-cors-headers==3.11.0
|
django-cors-headers==3.11.0
|
||||||
django-db-logger==0.1.12
|
django-db-logger==0.1.12
|
||||||
|
django-simple-history==3.1.1
|
||||||
djangorestframework==3.13.1
|
djangorestframework==3.13.1
|
||||||
google-auth==2.6.6
|
google-auth==2.6.6
|
||||||
gunicorn==20.1.0
|
gunicorn==20.1.0
|
||||||
|
@ -26,17 +28,18 @@ platformdirs==2.5.1
|
||||||
psycopg2-binary==2.9.3
|
psycopg2-binary==2.9.3
|
||||||
pyasn1==0.4.8
|
pyasn1==0.4.8
|
||||||
pyasn1-modules==0.2.8
|
pyasn1-modules==0.2.8
|
||||||
|
PyJWT==2.4.0
|
||||||
pylint==2.13.5
|
pylint==2.13.5
|
||||||
python-dotenv==0.20.0
|
python-dotenv==0.20.0
|
||||||
pytz==2022.1
|
pytz==2022.1
|
||||||
PyJWT==2.3.0
|
|
||||||
requests==2.27.1
|
requests==2.27.1
|
||||||
rsa==4.8
|
rsa==4.8
|
||||||
six==1.16.0
|
six==1.16.0
|
||||||
sqlparse==0.4.2
|
sqlparse==0.4.2
|
||||||
toml==0.10.2
|
toml==0.10.2
|
||||||
typing_extensions==4.1.1
|
tomli==2.0.1
|
||||||
|
typing-extensions==4.1.1
|
||||||
urllib3==1.26.9
|
urllib3==1.26.9
|
||||||
whitenoise==6.0.0
|
whitenoise==6.0.0
|
||||||
zipp==3.8.0
|
|
||||||
wrapt==1.14.0
|
wrapt==1.14.0
|
||||||
|
zipp==3.8.0
|
||||||
|
|
Loading…
Reference in New Issue