import json
import copy
from django.http import JsonResponse
from django.db.models import Q
from rest_framework import viewsets, permissions, status, filters
from rest_framework.filters import OrderingFilter
from django_redis import get_redis_connection
from update.models import Cinema
from update.serializers import *
from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework_extensions.cache.mixins import CacheResponseMixin
from django.utils.decorators import method_decorator
from django.views.decorators.cache import cache_page
from django.views.decorators.csrf import csrf_exempt
from django_filters.rest_framework import DjangoFilterBackend
from django.core.cache import cache
from update.utils.get_version import GetVersion
from rest_framework.decorators import action
from update.utils.git_util import GitUtil, GitDbUtil
from update.utils.cmd_extcute import UpdateCommandUtil, UpdateConfigUtil
from update.utils.db_compare import DbCompare
from update.utils.client_util import ClientUtil
# from consumers import UpdateConsumer
# cinema_update_status = dict()
# CacheResponseMixin 一定要放第一位
class CinemaViewSet(CacheResponseMixin, viewsets.ModelViewSet):
# 接口文档的中文注释
"""
create: 添加测试影院
list: 获取测试影院列表
retrieve: 获取某个影院的信息
update: 更新某个影院的信息
delete: 删除指定影院
"""
queryset = Cinema.objects.all()
serializer_class = CinemaSerializer
# permission_classes = (permissions.IsAuthenticated,)
filter_backends = (filters.SearchFilter, DjangoFilterBackend, OrderingFilter)
ordering_fields = ('ip',)
search_fields = ('sys_ver',)
# filter_fields = ('ip',)
filterset_fields = ('ip',)
GetVersion().main_process()
@action(methods=['get'], detail=False)
@method_decorator(cache_page(60 * 1))
def refresh(self, request, *args, **kwargs):
GetVersion().main_process()
queryset = Cinema.objects.all().order_by('ip')
serializer = self.get_serializer(instance=queryset, many=True)
return Response(serializer.data)
class CinemaUserViewSet(CacheResponseMixin, viewsets.ModelViewSet):
queryset = CinemaUser.objects.order_by('pinyin').all()
serializer_class = CinemaUserSerializer
class UpdateAlterViewSet(CacheResponseMixin, viewsets.ModelViewSet):
queryset = UpdateAlter.objects.all()
serializer_class = UpdateAlterSerializer
# class CinemaSearchAPIView(APIView, CacheResponseMixin):
# @method_decorator(cache_page(60 * 5))
# def get(self, request, *args, **kwargs):
# query_params = request.query_params.dict()
# print(query_params)
# query_data = Cinema.objects.filter(
# Q(ip__contains=query_params.get('ip')) & Q(sys_ver__icontains=query_params.get('version')))
# serializer = CinemaSerializer(instance=query_data, many=True)
# return Response(serializer.data, status=status.HTTP_200_OK)
@csrf_exempt
def update_user(request, *args, **kwargs):
cinema_id = request.GET.dict().get('id')
user = json.loads(request.body).get('user', '暂无')
result = Cinema.objects.filter(id=cinema_id).update(user=user)
return JsonResponse({'result': 'success'} if result == 1 else {'result': 'fail'})
def get_operation_cmd(request):
update_cmd = UpdateCommandUtil()
no_sys_cmd = update_cmd.get_no_sys_cmd()
serializer = UpdateCommandSerializer(instance=no_sys_cmd, many=True)
return JsonResponse(serializer.data, safe=False)
def get_git_version(request):
git_db_util = GitDbUtil()
git_db_util.set_release_to_db()
git_ver = git_db_util.get_short_version()
serializer = ReleaseSerializer(instance=git_ver, many=True)
return JsonResponse(serializer.data, safe=False)
def update_cine(request):
req = request.GET.dict()
cinema_ip = req.get('ip')
# 处理命令格式
cmd_dict = {}
cmd_obj = UpdateCommand.objects.filter(is_sys=0).values('id', 'process')
for cmd in cmd_obj:
if cmd['process'] in cmd_dict.keys():
cmd_dict[cmd['process']].append(cmd['id'])
else:
cmd_dict[cmd['process']] = [cmd['id']]
print(cmd_dict)
# 增加状态
update_status = {
'git': {'result': '', 'msg': ''},
'setup': {'result': '', 'msg': ''},
'sql': {'result': '', 'msg': ''},
'teardown': {'result': '', 'msg': ''},
'config': {'result': '', 'msg': ''},
'client': {'result': '', 'msg': ''},
}
# cinema_update_status[cinema_ip] = copy.deepcopy(update_status)
# 初始化redis
redis_conn = get_redis_connection()
redis_key = f'cinema_update_status_{cinema_ip}'
if redis_conn.exists(redis_key):
# update_status = copy.deepcopy(json.loads(redis_conn.get(redis_key)))
print('redis存在key', redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': '该影院正在升级中,请稍后再试!'})
else:
redis_conn.set(redis_key, json.dumps(update_status), 10*60)
print('update_status', update_status)
# redis_conn.set(f'cinema_update_status_{cinema_ip}', json.dumps(update_status), 10*60)
# print("ws调试", cinema_update_status)
short_release = req.get('version')
cmd_list = json.loads(req.get('cmd'))
print(cinema_ip, short_release, cmd_list)
# cinema_ip = '172.16.3.88'
# short_release = '2.0.33.0338_Release'
# cmd_list = [10, 11, 12, 13, 14, 15, 16, 17, 19, 20]
# 获取并写入cine.sql
print('获取并写入cine.sql')
try:
update_status['git']['result'] = 'running'
git_util = GitUtil(short_release)
git_output = git_util.handle_create_cine()
update_status['git']['result'] = 'success'
update_status['git']['msg'] = git_output
redis_conn.set(redis_key, json.dumps(update_status), 5*60)
except Exception as e:
print('git', e)
update_status['git']['result'] = 'fail'
update_status['git']['msg'] = str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
# 执行setup
print('执行setup')
try:
update_status['setup']['result'] = 'running'
setup_list = list(set(cmd_list) & set(cmd_dict['setup']))
update_cmd = UpdateCommandUtil()
result, setup_output = update_cmd.exec_cmd_by_type(cinema_ip, 'setup', setup_list, short_release)
if result is False:
raise Exception(setup_output)
update_status['setup']['result'] = 'success'
update_status['setup']['msg'] = setup_output
redis_conn.set(redis_key, json.dumps(update_status), 5 * 60)
except Exception as e:
print('setup', e)
update_status['setup']['result'] = 'fail'
update_status['setup']['msg'] = str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
# 数据库对比
sql_list = list(set(cmd_list) & set(cmd_dict['sql']))
if len(sql_list) > 0:
print('数据库对比')
try:
update_status['sql']['result'] = 'running'
db_compare = DbCompare(cinema_ip, short_release)
sql_output = db_compare.exec_diff_sql()
update_status['sql']['result'] = 'success'
update_status['sql']['msg'] = sql_output
redis_conn.set(redis_key, json.dumps(update_status), 5 * 60)
except Exception as e:
print('sql', e)
update_status['sql']['result'] = 'fail'
update_status['sql']['msg'] = str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
# 修改设置
print('执行config(teardown前)')
try:
update_status['config']['result'] = 'running'
config_list = list(set(cmd_list) & set(cmd_dict['config']))
update_config = UpdateConfigUtil(cinema_ip, config_list, True)
config_before_output = update_config.exec_config()
update_status['config']['result'] = 'success'
update_status['config']['msg'] = config_before_output
redis_conn.set(redis_key, json.dumps(update_status), 5 * 60)
except Exception as e:
print('config', e)
update_status['config']['result'] = 'fail'
update_status['config']['msg'] = str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
# 执行teardown
teardown_list = list(set(cmd_list) & set(cmd_dict['teardown']))
if len(teardown_list) > 0:
print('执行teardown')
try:
update_status['teardown']['result'] = 'running'
update_cmd = UpdateCommandUtil()
result, teardown_output = update_cmd.exec_cmd_by_type(cinema_ip, 'teardown', teardown_list, short_release)
if result is False:
raise Exception(teardown_output)
update_status['teardown']['result'] = 'success'
update_status['teardown']['msg'] = '执行升级脚本:执行成功'
redis_conn.set(redis_key, json.dumps(update_status), 5 * 60)
except Exception as e:
print('teardown', e)
update_status['teardown']['result'] = 'fail'
update_status['teardown']['msg'] = str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
# 修改设置
print('执行config(teardown后)')
try:
update_status['config']['result'] = 'running'
config_list = list(set(cmd_list) & set(cmd_dict['config']))
update_config = UpdateConfigUtil(cinema_ip, config_list, False)
config_after_output = update_config.exec_config()
update_status['config']['result'] = 'success'
update_status['config']['msg'] = config_before_output + '
' + config_after_output
redis_conn.set(redis_key, json.dumps(update_status), 5 * 60)
except Exception as e:
print('config', e)
update_status['config']['result'] = 'fail'
update_status['config']['msg'] = config_before_output + '
' + str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
# 传输客户端
client_list = list(set(cmd_list) & set(cmd_dict['client']))
if len(client_list) > 0:
print('传输客户端1')
try:
client_release = ClientUtil()
client_release.client_process(cinema_ip, short_release)
update_status['client']['result'] = 'success'
update_status['client']['msg'] = '客户端上传成功'
redis_conn.set(redis_key, json.dumps(update_status), 5 * 60)
except Exception as e:
print('client', e)
update_status['client']['result'] = 'fail'
update_status['client']['msg'] = str(e)
# redis_conn.delete(redis_key)
return JsonResponse({'result': 'fail', 'ip': cinema_ip, 'msg': str(e)})
print('update_status', update_status)
print('redis_get', redis_conn.get(redis_key))
return JsonResponse({'result': 'success', 'ip': cinema_ip, 'msg': ''})
# # 测试用接口
def write_git_version_to_db(request):
git_util = GitDbUtil()
git_util.set_release_to_db()
return JsonResponse({'result': 'success'})
#
#
# def write_cine_sql(request):
# git_util = GitUtil('2.0.33.0338_Release')
# git_util.handle_create_cine()
# return JsonResponse({'result': 'success'})
#
#
# def compare_db_structor(request):
# db_compare = DbCompare('172.16.3.88', '2.0.33.0338_Release')
# db_compare.exec_diff_sql()
# return JsonResponse({'result': 'success'})
#
#
# def get_cmd(request):
# update_cmd = UpdateCommandUtil()
# update_cmd.connect('172.16.3.112')
# update_cmd.disconnect()
# # cmd = update_cmd.get_all_cmd()
# # cmd_ser = UpdateCommandSerializer(instance=cmd, many=True)
# # return JsonResponse(data=cmd_ser.data, safe=False)
# cmd_list = [10, 12, 13, 14, 15, 17, 19, 20]
# r = update_cmd.get_checked_cmd(cmd_list)
# print(r)
# return JsonResponse({'result': 'success'})
#
#
# def setup_cmd(request):
# update_cmd = UpdateCommandUtil()
# cmd_list = [10, 11, 12, 13, 14, 15, 16, 17, 19, 20]
# # exec_cmd_data = update_cmd.get_checked_cmd(cmd_list)
# update_cmd.exec_cmd_by_type('172.16.3.88', 'setup', cmd_list, '2.0.33.0338_Release')
# return JsonResponse({'result': 'success'})
#
#
# def teardown_cmd(request):
# update_cmd = UpdateCommandUtil()
# cmd_list = [10, 11, 12, 13, 14, 15, 16, 17, 19, 20]
# # exec_cmd_data = update_cmd.get_checked_cmd(cmd_list)
# update_cmd.exec_cmd_by_type('172.16.3.88', 'teardown', cmd_list, '2.0.33.0338_Release')
# return JsonResponse({'result': 'success'})
#
#
# def get_client(request):
# client_release = ClientUtil()
# client_release.client_process('172.16.3.88', '2.0.33.0338_Release')
# return JsonResponse({'result': 'success'})