a8a615a900a991d8600afc2a342f0e9406851ffa
[vfc/gvnfm/vnflcm.git] / lcm / lcm / jobs / job_get.py
1 # Copyright 2017 ZTE Corporation.
2 #
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
6 #
7 #         http://www.apache.org/licenses/LICENSE-2.0
8 #
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
14 import logging
15
16 from lcm.pub.utils.jobutil import JobUtil
17
18 logger = logging.getLogger(__name__)
19
20
21 class GetJobInfoService(object):
22     def __init__(self, job_id, response_id=0):
23         self.job_id = job_id
24         self.response_id = response_id if response_id else 0
25
26     def do_biz(self):
27         # logger.info("get job info, job_id=:%s, response_id=:%s" % (self.job_id, self.response_id))
28         jobs = JobUtil.query_job_status(self.job_id, self.response_id)
29         if not jobs:
30             return {"jobId": self.job_id}
31         ret = {
32             "jobId": self.job_id,
33             "responseDescriptor": {
34                 "status": jobs[0].status,
35                 "progress": jobs[0].progress,
36                 "statusDescription": jobs[0].descp,
37                 "errorCode": jobs[0].errcode,
38                 "responseId": jobs[0].indexid,
39                 "responseHistoryList": [
40                     {
41                         "status": job.status,
42                         "progress": job.progress,
43                         "statusDescription": job.descp,
44                         "errorCode": job.errcode,
45                         "responseId": job.indexid} for job in jobs[1:]]}}
46         return ret