Fakultas Ilmu Komputer UI

vacancies.py 8.05 KB
Newer Older
1
2
import requests
from django.conf import settings
3
from rest_framework import viewsets, status
4
from rest_framework.exceptions import ValidationError
5
from rest_framework.generics import get_object_or_404
6
from rest_framework.permissions import IsAuthenticated
7
from rest_framework.response import Response
8
from rest_framework.decorators import detail_route
9

10
from core.lib.permissions import IsAdminOrStudent, IsAdminOrCompany, IsAdminOrVacancyOwner
11
from core.models import Student, Company
12
from core.models.vacancies import Vacancy, Application
13
14
from core.serializers.vacancies import VacancySerializer, ApplicationSerializer, ApplicationStatusSerializer, \
    VacancyApplicationSerializer
15
16
17


class VacancyViewSet(viewsets.ModelViewSet):
18
    queryset = Vacancy.objects.all()
19
    serializer_class = VacancySerializer
20
    permission_classes = [IsAdminOrCompany]
21

22
    def get_permissions(self):
23
        if self.action in ["retrieve", "list"]:
24
25
26
            return [IsAuthenticated()]
        return super(VacancyViewSet, self).get_permissions()

27
28
    def list(self, request, *args, **kwargs):
        vacancies = Vacancy.objects.all()
29
30
        verified = request.query_params['verified'] if 'verified' in request.query_params else "True"
        if verified.lower() in ("yes", "true", "t", "1"):
31
            vacancies = vacancies.filter(verified=True)
32

33
34
        return Response(VacancySerializer(vacancies, many=True, context={'request': request}).data)

35
36
37
38
39
40
41
    @detail_route(permission_classes=[IsAdminOrCompany])
    def count(self, request, pk=None):
        vacancy = self.get_object()
        count = Application.objects.filter(vacancy=vacancy).count()
        count_new = Application.objects.filter(vacancy=vacancy, status=Application.NEW).count()
        return Response({"count": count, "count_new": count_new}, status=status.HTTP_200_OK)

42

43
class ApplicationViewSet(viewsets.GenericViewSet):
44
    serializer_class = ApplicationSerializer
45
    permission_classes = [IsAdminOrStudent]
46

47
    def list(self, request, student_id):
48
        """
49
        Get list of a student {student_id}'s applications
50
51
        ---
        """
52
        student = get_object_or_404(Student.objects.all(), pk=student_id)
53
54
        applications = Application.objects.filter(student=student)
        return Response(VacancyApplicationSerializer(applications, many=True, context={'request': request}).data)
55
56

    def create(self, request, student_id):
57
58
59
60
61
        """
        Create a new application for student {student_id}
        ---
        parameters:
            - name: body
62
              description: JSON object containing an integer 'vacancy_id' and a string 'cover_letter'
63
64
65
66
              required: true
              type: string
              paramType: body
        """
67
68
        cover_letter = request.data.get('cover_letter')
        vacancy = get_object_or_404(Vacancy.objects.all(), pk=request.data.get('vacancy_id'))
69
        student = get_object_or_404(Student.objects.all(), pk=student_id)
70
71
        if Application.objects.filter(vacancy=vacancy, student=student).exists():
            raise ValidationError("You have already applied for the vacancy")
72
73
74
        application = Application(vacancy=vacancy, student=student, cover_letter=cover_letter)
        application.save()
        return Response(ApplicationSerializer(application, context={'request': request}).data)
75
76

    def destroy(self, request, student_id, pk):
77
78
79
80
        """
        Remove a application {id} for student {student_id}
        ---
        """
81
82
        vacancy = get_object_or_404(Vacancy.objects.all(), pk=pk)
        student = get_object_or_404(Student.objects.all(), pk=student_id)
83
        application = get_object_or_404(Application.objects.all(), student=student, vacancy=vacancy)
84
        application.delete()
85
        return Response(ApplicationSerializer(application, context={'request': request}).data)
86

87

88
89
class CompanyApplicationViewSet(viewsets.GenericViewSet):
    queryset = Application.objects.all()
90
    permission_classes = [IsAdminOrCompany]
91
92
93
94
95
96
97

    def list(self, request, company_id):
        """
        Get list of company {company_id}'s applications
        ---
        """
        company = get_object_or_404(Company.objects.all(), pk=company_id)
98
99
100
101
        vacancies = Vacancy.objects.filter(company=company)
        applications = Application.objects.filter(vacancy__in=vacancies)
        if 'status' in request.query_params:
            applications = applications.filter(status=request.query_params['status'])
102
103
104
        return Response(ApplicationSerializer(applications, many=True, context={'request': request}).data)


105
106
107
108
109
110
111
112
113
114
115
116
117
118
class CompanyApplicationStatusViewSet(viewsets.GenericViewSet):
    queryset = Application.objects.all()
    serializer_class = ApplicationStatusSerializer
    permission_classes = [IsAdminOrVacancyOwner]

    def partial_update(self, request, pk=None):
        application = self.get_object()
        serializer = self.get_serializer_class()(application, data=request.data, partial=True)
        if serializer.is_valid():
            serializer.save()
            return Response(serializer.data, status=status.HTTP_202_ACCEPTED)
        else:
            return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)

119
120
121
122
123
124
125
126
    def retrieve(self, request, pk=None):
        application = self.get_object()
        student = application.student
        if student.show_transcript:
            s = requests.Session()
            credentials = settings.API_CS_CREDENTIALS
            s.get('https://api.cs.ui.ac.id/api-auth/login/')
            csrf = s.cookies['csrftoken']
127
            resp = s.post('https://api.cs.ui.ac.id/api-auth/login/', data={'username' : credentials["user"], 'password' : credentials["password"], 'csrfmiddlewaretoken' : csrf})
128
            response = s.get('https://api.cs.ui.ac.id/siakngcs/mahasiswa/' + str(student.npm) + '/riwayat/')
129
            return Response({'name' : student.full_name, 'transcript' : response.json()}, status=status.HTTP_200_OK)
130
        else:
131
            return Response({'name' : student.full_name, 'error' : 'student does not allow transcript to be shown'}, status=status.HTTP_200_OK)
132

133

134
class CompanyVacanciesViewSet(viewsets.GenericViewSet):
135
    queryset = Vacancy.objects.all()
136
137
138
139
140
141

    def list(self, request, company_id):
        """
        Get list of company {company_id}'s vacancies
        ---
        """
142
143
        company = get_object_or_404(Company.objects.all().order_by('-updated'), pk=company_id)
        vacancies = Vacancy.objects.filter(company=company)
144
145
146
        return Response(VacancySerializer(vacancies, many=True, context={'request': request}).data)


147
148
149
150
151
class BookmarkedVacancyByStudentViewSet(viewsets.GenericViewSet):
    serializer_class = VacancySerializer
    permission_classes = [IsAdminOrStudent]

    def list(self, request, student_id):
152
153
154
155
        """
        Get list of a student {student_id}'s bookmarked vacancies
        ---
        """
156
157
158
159
160
        student = get_object_or_404(Student.objects.all(), pk=student_id)
        vacancies = self.serializer_class(student.bookmarked_vacancies, many=True, context={'request': request})
        return Response(vacancies.data)

    def create(self, request, student_id):
161
162
163
164
165
166
167
168
169
170
        """
        Bookmarks a vacancy for student {student_id}
        ---
        parameters:
            - name: body
              description: JSON object containing only one string: vacancy_id
              required: true
              type: string
              paramType: body
        """
171
172
173
174
175
176
        vacancy = get_object_or_404(Vacancy.objects.all(), pk=request.data['vacancy_id'])
        student = get_object_or_404(Student.objects.all(), pk=student_id)
        student.bookmarked_vacancies.add(vacancy)
        return Response(self.serializer_class(student.bookmarked_vacancies, many=True, context={'request': request}).data)

    def destroy(self, request, student_id, pk):
177
178
179
180
        """
        Remove bookmark {id} for student {student_id}
        ---
        """
181
182
183
184
        vacancy = get_object_or_404(Vacancy.objects.all(), pk=pk)
        student = get_object_or_404(Student.objects.all(), pk=student_id)
        student.bookmarked_vacancies.remove(vacancy)
        return Response(self.serializer_class(student.bookmarked_vacancies, many=True, context={'request': request}).data)