|
|
|
|
|
|
|
|
|
|
|
from django.contrib.auth.decorators import login_required |
|
|
from django.shortcuts import render, redirect |
|
|
from django.shortcuts import render, redirect |
|
|
|
|
|
from django.views.decorators.csrf import csrf_exempt |
|
|
|
|
|
from rest_framework.parsers import JSONParser |
|
|
|
|
|
|
|
|
from posts.forms import NoticeForm |
|
|
from posts.forms import NoticeForm |
|
|
|
|
|
from posts.serializers import NoticeSerializer |
|
|
from.models import Notice |
|
|
from.models import Notice |
|
|
from django.utils import timezone |
|
|
from django.utils import timezone |
|
|
from django.http import HttpResponse |
|
|
|
|
|
|
|
|
from django.http import HttpResponse, JsonResponse |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def index(request): |
|
|
def index(request): |
|
|
notices= Notice.objects.all() |
|
|
notices= Notice.objects.all() |
|
|
|
|
|
|
|
|
context={"notices":notices} |
|
|
context={"notices":notices} |
|
|
return render(request, 'posts/notice.html', context) |
|
|
return render(request, 'posts/notice.html', context) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@login_required |
|
|
def new(request): |
|
|
def new(request): |
|
|
if request.method == "POST": |
|
|
if request.method == "POST": |
|
|
form = NoticeForm(request.POST) |
|
|
form = NoticeForm(request.POST) |
|
|
|
|
|
|
|
|
delNotice= Notice.objects.get(id=deleteId) |
|
|
delNotice= Notice.objects.get(id=deleteId) |
|
|
if delNotice!= None: |
|
|
if delNotice!= None: |
|
|
delNotice.delete() |
|
|
delNotice.delete() |
|
|
return redirect('index') |
|
|
|
|
|
|
|
|
return redirect('index') |
|
|
|
|
|
@csrf_exempt |
|
|
|
|
|
def notice_list(request): |
|
|
|
|
|
if request.method == 'GET': |
|
|
|
|
|
notices = Notice.objects.all() |
|
|
|
|
|
serializer = NoticeSerializer(notices, many=True) |
|
|
|
|
|
return JsonResponse(serializer.data, safe=False) |
|
|
|
|
|
elif request.method=='POST': |
|
|
|
|
|
data = JSONParser().parse(request) |
|
|
|
|
|
serializer = NoticeSerializer(data=data) |
|
|
|
|
|
if serializer.is_valid(): |
|
|
|
|
|
serializer.save() |
|
|
|
|
|
return JsonResponse(serializer.data, status=201) |
|
|
|
|
|
return JsonResponse(serializer.errors, status=201) |
|
|
|
|
|
@csrf_exempt |
|
|
|
|
|
def notice_detail(request, id): |
|
|
|
|
|
try: |
|
|
|
|
|
notice= Notice.objects.get(id =id) |
|
|
|
|
|
except Notice.DoesNotExist: |
|
|
|
|
|
return HttpResponse(status=404) |
|
|
|
|
|
if request.method =='GET': |
|
|
|
|
|
serializer = NoticeSerializer(notice) |
|
|
|
|
|
return JsonResponse(serializer.data) |
|
|
|
|
|
elif request.method =='PUT': |
|
|
|
|
|
data = JSONParser().parse(request) |
|
|
|
|
|
serializer = NoticeSerializer(notice, data=data) |
|
|
|
|
|
if serializer.is_valid(): |
|
|
|
|
|
serializer.save() |
|
|
|
|
|
return JsonResponse(serializer.data) |
|
|
|
|
|
return JsonResponse(serializer.errors, status=400) |
|
|
|
|
|
elif request.method == 'DELETE': |
|
|
|
|
|
notice.delete() |
|
|
|
|
|
return HttpResponse(status=204) |