You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.1 KiB
69 lines
2.1 KiB
4 weeks ago
|
# 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 Banner
|
||
|
from myapp.permission.permission import isDemoAdminUser
|
||
|
from myapp.serializers import BannerSerializer
|
||
|
|
||
|
|
||
|
@api_view(['GET'])
|
||
|
def list_api(request):
|
||
|
if request.method == 'GET':
|
||
|
banners = Banner.objects.all().order_by('-create_time')
|
||
|
serializer = BannerSerializer(banners, 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 = BannerSerializer(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)
|
||
|
banner = Banner.objects.get(pk=pk)
|
||
|
except Banner.DoesNotExist:
|
||
|
return APIResponse(code=1, msg='对象不存在')
|
||
|
|
||
|
serializer = BannerSerializer(banner, 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(',')
|
||
|
Banner.objects.filter(id__in=ids_arr).delete()
|
||
|
except Banner.DoesNotExist:
|
||
|
return APIResponse(code=1, msg='对象不存在')
|
||
|
|
||
|
return APIResponse(code=0, msg='删除成功')
|