mirror of https://github.com/jumpserver/jumpserver
feat: 批量命令api
parent
8de2ffe5f4
commit
e32d51253a
|
@ -5,11 +5,12 @@ from rest_framework.response import Response
|
||||||
from ops.models import Job, JobExecution
|
from ops.models import Job, JobExecution
|
||||||
from ops.serializers.job import JobSerializer, JobExecutionSerializer
|
from ops.serializers.job import JobSerializer, JobExecutionSerializer
|
||||||
|
|
||||||
__all__ = ['JobViewSet', 'JobExecutionViewSet', 'JobRunVariableHelpAPIView', 'JobAssetDetail', ]
|
__all__ = ['JobViewSet', 'JobExecutionViewSet', 'JobRunVariableHelpAPIView', 'JobAssetDetail', 'JobExecutionTaskDetail']
|
||||||
|
|
||||||
from ops.tasks import run_ops_job_execution
|
from ops.tasks import run_ops_job_execution
|
||||||
from ops.variables import JMS_JOB_VARIABLE_HELP
|
from ops.variables import JMS_JOB_VARIABLE_HELP
|
||||||
from orgs.mixins.api import OrgBulkModelViewSet
|
from orgs.mixins.api import OrgBulkModelViewSet
|
||||||
|
from orgs.utils import tmp_to_org, get_current_org_id, get_current_org
|
||||||
|
|
||||||
|
|
||||||
def set_task_to_serializer_data(serializer, task):
|
def set_task_to_serializer_data(serializer, task):
|
||||||
|
@ -93,3 +94,20 @@ class JobAssetDetail(APIView):
|
||||||
if execution_id:
|
if execution_id:
|
||||||
execution = get_object_or_404(JobExecution, id=execution_id)
|
execution = get_object_or_404(JobExecution, id=execution_id)
|
||||||
return Response(data=execution.assent_result_detail)
|
return Response(data=execution.assent_result_detail)
|
||||||
|
|
||||||
|
|
||||||
|
class JobExecutionTaskDetail(APIView):
|
||||||
|
rbac_perms = ()
|
||||||
|
permission_classes = ()
|
||||||
|
|
||||||
|
def get(self, request, **kwargs):
|
||||||
|
org = get_current_org()
|
||||||
|
task_id = request.query_params.get('task_id')
|
||||||
|
if task_id:
|
||||||
|
with tmp_to_org(org):
|
||||||
|
execution = get_object_or_404(JobExecution, task_id=task_id)
|
||||||
|
return Response(data={
|
||||||
|
'is_finished': execution.is_finished,
|
||||||
|
'is_success': execution.is_success,
|
||||||
|
'time_cost': execution.time_cost,
|
||||||
|
})
|
||||||
|
|
|
@ -25,6 +25,7 @@ router.register(r'task-executions', api.CeleryTaskExecutionViewSet, 'task-execut
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('variables/help/', api.JobRunVariableHelpAPIView.as_view(), name='variable-help'),
|
path('variables/help/', api.JobRunVariableHelpAPIView.as_view(), name='variable-help'),
|
||||||
path('job-execution/asset-detail/', api.JobAssetDetail.as_view(), name='asset-detail'),
|
path('job-execution/asset-detail/', api.JobAssetDetail.as_view(), name='asset-detail'),
|
||||||
|
path('job-execution/task-detail/', api.JobExecutionTaskDetail.as_view(), name='task-detail'),
|
||||||
path('ansible/job-execution/<uuid:pk>/log/', api.AnsibleTaskLogApi.as_view(), name='job-execution-log'),
|
path('ansible/job-execution/<uuid:pk>/log/', api.AnsibleTaskLogApi.as_view(), name='job-execution-log'),
|
||||||
|
|
||||||
path('celery/task/<uuid:name>/task-execution/<uuid:pk>/log/', api.CeleryTaskExecutionLogApi.as_view(),
|
path('celery/task/<uuid:name>/task-execution/<uuid:pk>/log/', api.CeleryTaskExecutionLogApi.as_view(),
|
||||||
|
|
|
@ -67,11 +67,12 @@ class TaskLogWebsocket(AsyncJsonWebsocketConsumer):
|
||||||
task_end_mark.append(1)
|
task_end_mark.append(1)
|
||||||
elif len(task_end_mark) == 2:
|
elif len(task_end_mark) == 2:
|
||||||
logger.debug('Task log end: {}'.format(task_id))
|
logger.debug('Task log end: {}'.format(task_id))
|
||||||
|
await self.send_json({'event': 'end', 'task': task_id})
|
||||||
break
|
break
|
||||||
await asyncio.sleep(0.2)
|
await asyncio.sleep(0.2)
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
logger.warn('Task log path open failed: {}'.format(e))
|
logger.warn('Task log path open failed: {}'.format(e))
|
||||||
await self.close()
|
# await self.close()
|
||||||
|
|
||||||
async def disconnect(self, close_code):
|
async def disconnect(self, close_code):
|
||||||
self.disconnected = True
|
self.disconnected = True
|
||||||
|
|
Loading…
Reference in New Issue