# Create your views here. from rest_framework.decorators import api_view, authentication_classes from myapp.auth.authentication import AdminTokenAuthtication from myapp.handler import APIResponse from myapp.models import Ad from myapp.permission.permission import isDemoAdminUser from myapp.serializers import AdSerializer @api_view(['GET']) def list_api(request): if request.method == 'GET': ads = Ad.objects.all().order_by('-create_time') serializer = AdSerializer(ads, many=True) return APIResponse(code=0, msg='查询成功', data=serializer.data) @api_view(['POST']) @authentication_classes([AdminTokenAuthtication]) def create(request): if isDemoAdminUser(request): return APIResponse(code=1, msg='演示帐号无法操作') serializer = AdSerializer(data=request.data) if serializer.is_valid(): serializer.save() return APIResponse(code=0, msg='创建成功', data=serializer.data) return APIResponse(code=1, msg='创建失败') @api_view(['POST']) @authentication_classes([AdminTokenAuthtication]) def update(request): if isDemoAdminUser(request): return APIResponse(code=1, msg='演示帐号无法操作') try: pk = request.GET.get('id', -1) ad = Ad.objects.get(pk=pk) except Ad.DoesNotExist: return APIResponse(code=1, msg='对象不存在') serializer = AdSerializer(ad, data=request.data) if serializer.is_valid(): serializer.save() return APIResponse(code=0, msg='更新成功', data=serializer.data) else: print(serializer.errors) return APIResponse(code=1, msg='更新失败') @api_view(['POST']) @authentication_classes([AdminTokenAuthtication]) def delete(request): if isDemoAdminUser(request): return APIResponse(code=1, msg='演示帐号无法操作') try: ids = request.GET.get('ids') ids_arr = ids.split(',') Ad.objects.filter(id__in=ids_arr).delete() except Ad.DoesNotExist: return APIResponse(code=1, msg='对象不存在') return APIResponse(code=0, msg='删除成功')