This commit is contained in:
0
iris-web/source/app/datamgmt/overview/__init__.py
Normal file
0
iris-web/source/app/datamgmt/overview/__init__.py
Normal file
70
iris-web/source/app/datamgmt/overview/overview_db.py
Normal file
70
iris-web/source/app/datamgmt/overview/overview_db.py
Normal file
@@ -0,0 +1,70 @@
|
||||
#!/usr/bin/env python3
|
||||
#
|
||||
# IRIS Source Code
|
||||
# DFIR-IRIS Team
|
||||
# contact@dfir-iris.org
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU Lesser General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 3 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# Lesser General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public License
|
||||
# along with this program; if not, write to the Free Software Foundation,
|
||||
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
import datetime
|
||||
from sqlalchemy import and_
|
||||
|
||||
from app.datamgmt.case.case_tasks_db import get_tasks_cases_mapping
|
||||
from app.datamgmt.manage.manage_cases_db import user_list_cases_view
|
||||
from app.models import Cases, CaseClassification
|
||||
from app.models import Client
|
||||
from app.models.authorization import User
|
||||
from app.models.cases import CaseState
|
||||
from app.schema.marshables import CaseDetailsSchema
|
||||
|
||||
|
||||
def get_overview_db(user_id, show_full):
|
||||
"""
|
||||
Get overview data from the database
|
||||
"""
|
||||
condition = and_(Cases.case_id.in_(user_list_cases_view(user_id)))
|
||||
|
||||
if not show_full:
|
||||
condition = and_(condition, Cases.close_date == None)
|
||||
|
||||
open_cases = Cases.query.filter(
|
||||
condition
|
||||
).join(
|
||||
Cases.owner,
|
||||
Cases.client
|
||||
).all()
|
||||
|
||||
cases_list = []
|
||||
tasks_map = get_tasks_cases_mapping(open_cases_only=not show_full)
|
||||
tmap = {}
|
||||
for task in tasks_map:
|
||||
if tmap.get(task.task_case_id) is None:
|
||||
tmap[task.task_case_id] = {
|
||||
'open_tasks': 0,
|
||||
'closed_tasks': 0
|
||||
}
|
||||
|
||||
if task.task_status_id in [1, 2, 3]:
|
||||
tmap[task.task_case_id]['open_tasks'] += 1
|
||||
elif task.task_status_id == 4:
|
||||
tmap[task.task_case_id]['closed_tasks'] += 1
|
||||
|
||||
# open_cases_list = []
|
||||
for case in open_cases:
|
||||
c_case = CaseDetailsSchema().dump(case)
|
||||
c_case['case_open_since_days'] = (datetime.date.today() - case.open_date).days
|
||||
c_case['tasks_status'] = tmap.get(case.case_id)
|
||||
cases_list.append(c_case)
|
||||
|
||||
return cases_list
|
Reference in New Issue
Block a user