view of export

This commit is contained in:
Cayo Puigdefabregas 2022-02-22 11:11:53 +01:00
parent 4ce359fec4
commit 60d9c04e2d
1 changed files with 40 additions and 2 deletions

View File

@ -1,8 +1,9 @@
import flask import flask
from flask import g from io import StringIO
from flask import Blueprint, request, url_for from flask import Blueprint, request, url_for, g, make_response
from flask.views import View from flask.views import View
from flask_login import current_user, login_required from flask_login import current_user, login_required
from werkzeug.exceptions import NotFound
from ereuse_devicehub import messages from ereuse_devicehub import messages
from ereuse_devicehub.inventory.forms import (AllocateForm, LotDeviceForm, from ereuse_devicehub.inventory.forms import (AllocateForm, LotDeviceForm,
@ -401,6 +402,42 @@ class NewTradeDocumentView(View):
return flask.render_template(self.template_name, form=self.form, title=self.title) return flask.render_template(self.template_name, form=self.form, title=self.title)
class ExportsView(View):
methods = ['GET']
decorators = [login_required]
def dispatch_request(self, export_id):
import pdb; pdb.trace()
export_ids = {
'metrics': self.metrics(),
'devices-list': self.metrics(),
'certificates': self.metrics()
}
if export_id not in export_ids:
return NotFound()
return export_ids[export_id]()
def metrics(self):
"""Get device query and put information in csv format."""
data = StringIO()
# cw = csv.writer(data, delimiter=';', lineterminator="\n", quotechar='"')
# first = True
# document_ids = self.get_documents_id()
# for device in query:
# d = DeviceRow(device, document_ids)
# if first:
# cw.writerow(d.keys())
# first = False
# cw.writerow(d.values())
bfile = data.getvalue().encode('utf-8')
output = make_response(bfile)
# insert_hash(bfile)
output.headers['Content-Disposition'] = 'attachment; filename=export.csv'
output.headers['Content-type'] = 'text/csv'
return output
devices.add_url_rule('/action/add/', view_func=NewActionView.as_view('action_add')) devices.add_url_rule('/action/add/', view_func=NewActionView.as_view('action_add'))
devices.add_url_rule('/action/trade/add/', view_func=NewTradeView.as_view('trade_add')) devices.add_url_rule('/action/trade/add/', view_func=NewTradeView.as_view('trade_add'))
devices.add_url_rule('/action/allocate/add/', view_func=NewAllocateView.as_view('allocate_add')) devices.add_url_rule('/action/allocate/add/', view_func=NewAllocateView.as_view('allocate_add'))
@ -423,3 +460,4 @@ devices.add_url_rule('/tag/unnamed/add/', view_func=TagAddUnnamedView.as_view('t
devices.add_url_rule('/tag/<string:id>/', view_func=TagDetailView.as_view('tag_details')) devices.add_url_rule('/tag/<string:id>/', view_func=TagDetailView.as_view('tag_details'))
devices.add_url_rule('/tag/devices/add/', view_func=TagLinkDeviceView.as_view('tag_devices_add')) devices.add_url_rule('/tag/devices/add/', view_func=TagLinkDeviceView.as_view('tag_devices_add'))
devices.add_url_rule('/tag/devices/<int:id>/del/', view_func=TagUnlinkDeviceView.as_view('tag_devices_del')) devices.add_url_rule('/tag/devices/<int:id>/del/', view_func=TagUnlinkDeviceView.as_view('tag_devices_del'))
devices.add_url_rule('/export/<string:export_id>', view_func=ExportsView.as_view('export'))