2024-07-20 15:48:46 +03:30
|
|
|
#!/usr/bin/python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
# api_bakcups.py: API for managing bakcups
|
|
|
|
# MikroWizard.com , Mikrotik router management solution
|
|
|
|
# Author: sepehr.ha@gmail.com
|
|
|
|
|
2024-07-31 17:41:12 +03:30
|
|
|
from flask import request, jsonify,session
|
2024-07-20 15:48:46 +03:30
|
|
|
|
2024-07-31 17:41:12 +03:30
|
|
|
from libs.db import db_tasks,db_backups,db_device,db_syslog,db_user_group_perm
|
2024-07-20 15:48:46 +03:30
|
|
|
from libs import util
|
|
|
|
from libs.webutil import app, login_required,buildResponse,get_myself,get_ip,get_agent
|
|
|
|
import bgtasks
|
|
|
|
import logging
|
|
|
|
import json
|
2024-07-31 17:41:12 +03:30
|
|
|
import datetime
|
|
|
|
from functools import reduce
|
|
|
|
import operator
|
|
|
|
try:
|
|
|
|
from libs import utilpro
|
|
|
|
ISPRO=True
|
|
|
|
except ImportError:
|
|
|
|
ISPRO=False
|
|
|
|
pass
|
2024-07-20 15:48:46 +03:30
|
|
|
log = logging.getLogger("api.firmware")
|
|
|
|
|
|
|
|
@app.route('/api/backup/make', methods = ['POST'])
|
|
|
|
@login_required(role='admin',perm={'backup':'write'})
|
|
|
|
def backup_create():
|
|
|
|
input = request.json
|
|
|
|
devids=input.get('devids',False)
|
|
|
|
status=db_tasks.backup_job_status().status
|
|
|
|
if not status:
|
|
|
|
db_syslog.add_syslog_event(get_myself(), "Backup Managment","Create", get_ip(),get_agent(),json.dumps(input))
|
|
|
|
if devids=="0":
|
|
|
|
all_devices=list(db_device.get_all_device())
|
|
|
|
bgtasks.backup_devices(devices=all_devices)
|
|
|
|
else:
|
|
|
|
devices=db_device.get_devices_by_id(devids)
|
|
|
|
bgtasks.backup_devices(devices=devices)
|
|
|
|
return buildResponse([{'status': status}],200)
|
|
|
|
else:
|
|
|
|
return buildResponse([{'status': status}],200)
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/api/backup/list', methods = ['POST'])
|
|
|
|
@login_required(role='admin',perm={'backup':'read'})
|
|
|
|
def backup_list():
|
|
|
|
input = request.json
|
2024-07-31 17:41:12 +03:30
|
|
|
event_start_time=input.get('start_time',False)
|
|
|
|
event_end_time=input.get('end_time',False)
|
2024-07-20 15:48:46 +03:30
|
|
|
devid = input.get('devid',False)
|
|
|
|
search = input.get('search')
|
2024-07-31 17:41:12 +03:30
|
|
|
uid = session.get("userid") or False
|
|
|
|
if not devid:
|
|
|
|
devs=list(db_user_group_perm.DevUserGroupPermRel.get_user_devices(uid))
|
|
|
|
dev_ids=[dev.id for dev in devs]
|
|
|
|
else:
|
|
|
|
dev=db_device.get_device(devid)
|
|
|
|
if not dev:
|
|
|
|
return buildResponse({'status': 'failed'}, 200, error="Wrong Data")
|
|
|
|
dev_ids=[devid]
|
|
|
|
backups = db_backups.Backups
|
|
|
|
log.error("1")
|
|
|
|
clauses = []
|
|
|
|
clauses.append(backups.devid << dev_ids)
|
|
|
|
if event_start_time:
|
|
|
|
event_start_time=event_start_time.split(".000Z")[0]
|
|
|
|
event_start_time=datetime.datetime.strptime(event_start_time, "%Y-%m-%dT%H:%M:%S")
|
|
|
|
clauses.append(backups.created >= event_start_time)
|
|
|
|
else:
|
|
|
|
clauses.append(backups.created >= datetime.datetime.now()-datetime.timedelta(days=1))
|
|
|
|
if event_end_time:
|
|
|
|
event_end_time=event_end_time.split(".000Z")[0]
|
|
|
|
event_end_time=datetime.datetime.strptime(event_end_time, "%Y-%m-%dT%H:%M:%S")
|
|
|
|
clauses.append(backups.created <= event_end_time)
|
|
|
|
else:
|
|
|
|
clauses.append(backups.created <= datetime.datetime.now())
|
|
|
|
expr=""
|
|
|
|
devs=db_device.Devices
|
|
|
|
try:
|
|
|
|
if len(clauses):
|
|
|
|
expr = reduce(operator.and_, clauses)
|
|
|
|
query=backups.select().where(expr)
|
|
|
|
else:
|
|
|
|
query=backups.select()
|
|
|
|
query=query.order_by(backups.id.desc())
|
|
|
|
backups=list(query)
|
|
|
|
except Exception as e:
|
|
|
|
log.error(e)
|
|
|
|
return buildResponse({"status":"failed", "err":str(e)}, 200)
|
2024-07-20 15:48:46 +03:30
|
|
|
reply=[]
|
2024-07-31 17:41:12 +03:30
|
|
|
log.error("backups")
|
|
|
|
if search and ISPRO:
|
|
|
|
backups=utilpro.search_in_backups(search, backups)
|
2024-07-20 15:48:46 +03:30
|
|
|
for back in backups:
|
|
|
|
data={}
|
|
|
|
if back.devid:
|
|
|
|
dev=back.devid
|
|
|
|
data['id']=back.id
|
|
|
|
data['filesize']=util.sizeof_fmt(back.filesize)
|
|
|
|
data['created']=back.created
|
|
|
|
data['devname']=dev.name
|
|
|
|
data['devip']=dev.ip
|
|
|
|
data['devmac']=dev.mac
|
|
|
|
else:
|
|
|
|
data['id']=back.id
|
|
|
|
data['filesize']=util.sizeof_fmt(back.filesize)
|
|
|
|
data['created']=back.created
|
|
|
|
data['devname']='Deleted Device'
|
|
|
|
data['devip']=''
|
|
|
|
data['devmac']=''
|
|
|
|
reply.append(data)
|
|
|
|
return buildResponse(reply, 200)
|
|
|
|
|
|
|
|
@app.route('/api/backup/get', methods = ['POST'])
|
|
|
|
@login_required(role='admin',perm={'backup':'read'})
|
|
|
|
def backup_get():
|
|
|
|
input = request.json
|
|
|
|
id=input.get('id')
|
2024-07-31 17:41:12 +03:30
|
|
|
try:
|
|
|
|
back=db_backups.get_backup(id)
|
|
|
|
path=back.dir
|
|
|
|
with open(path, 'r') as file:
|
|
|
|
file_content = file.read()
|
|
|
|
except Exception as e:
|
|
|
|
log.error(e)
|
|
|
|
return buildResponse({"status":"failed"}, 200)
|
2024-07-20 15:48:46 +03:30
|
|
|
return buildResponse({"content":file_content}, 200)
|
|
|
|
|
|
|
|
@app.route('/api/backup/status', methods = ['POST'])
|
|
|
|
@login_required(role='admin',perm={'backup':'read'})
|
|
|
|
def backup_status():
|
|
|
|
status=db_tasks.update_check_status().status
|
|
|
|
return jsonify({'status': status})
|