0c0153a037
Added a csv writer using the 'csv' library to format properly exported data - escaping, encoding etc. Added a HttpResponse-based class to handle csv generation Added translation for the CSV columns and template. Fix bug #1158383 Renamed few occurencies of 'tenant' to 'project'. Also added a new 'project' in nova_data.py, which required some refactoring of few tests, that didn't consider the current project for project-based calls. Note: I've added a StreamingHttpResponse example, which is introduced in Django 1.5+ and being advised in the ticket. However, my opinion is that at the moment we don't need this - it is too complicated for the current usage. Change-Id: I18bd70a23b7b8389c7c0f96dbf8794fea5e1e75b
73 lines
2.4 KiB
Python
73 lines
2.4 KiB
Python
from django.core import urlresolvers
|
|
from django.template.defaultfilters import floatformat
|
|
from django.template.defaultfilters import timesince
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from horizon import tables
|
|
from horizon.templatetags.sizeformat import mbformat
|
|
|
|
|
|
class CSVSummary(tables.LinkAction):
|
|
name = "csv_summary"
|
|
verbose_name = _("Download CSV Summary")
|
|
classes = ("btn-download",)
|
|
|
|
def get_link_url(self, usage=None):
|
|
return self.table.kwargs['usage'].csv_link()
|
|
|
|
|
|
class BaseUsageTable(tables.DataTable):
|
|
vcpus = tables.Column('vcpus', verbose_name=_("VCPUs"))
|
|
disk = tables.Column('local_gb', verbose_name=_("Disk"))
|
|
memory = tables.Column('memory_mb',
|
|
verbose_name=_("RAM"),
|
|
filters=(mbformat,),
|
|
attrs={"data-type": "size"})
|
|
hours = tables.Column('vcpu_hours', verbose_name=_("VCPU Hours"),
|
|
filters=(lambda v: floatformat(v, 2),))
|
|
|
|
|
|
class GlobalUsageTable(BaseUsageTable):
|
|
project = tables.Column('project_name', verbose_name=_("Project Name"))
|
|
disk_hours = tables.Column('disk_gb_hours',
|
|
verbose_name=_("Disk GB Hours"),
|
|
filters=(lambda v: floatformat(v, 2),))
|
|
|
|
def get_object_id(self, datum):
|
|
return datum.tenant_id
|
|
|
|
class Meta:
|
|
name = "global_usage"
|
|
verbose_name = _("Usage Summary")
|
|
columns = ("project", "vcpus", "disk", "memory",
|
|
"hours", "disk_hours")
|
|
table_actions = (CSVSummary,)
|
|
multi_select = False
|
|
|
|
|
|
def get_instance_link(datum):
|
|
view = "horizon:project:instances:detail"
|
|
if datum.get('instance_id', False):
|
|
return urlresolvers.reverse(view, args=(datum.get('instance_id'),))
|
|
else:
|
|
return None
|
|
|
|
|
|
class ProjectUsageTable(BaseUsageTable):
|
|
instance = tables.Column('name',
|
|
verbose_name=_("Instance Name"),
|
|
link=get_instance_link)
|
|
uptime = tables.Column('uptime_at',
|
|
verbose_name=_("Uptime"),
|
|
filters=(timesince,))
|
|
|
|
def get_object_id(self, datum):
|
|
return datum.get('instance_id', id(datum))
|
|
|
|
class Meta:
|
|
name = "project_usage"
|
|
verbose_name = _("Usage Summary")
|
|
columns = ("instance", "vcpus", "disk", "memory", "uptime")
|
|
table_actions = (CSVSummary,)
|
|
multi_select = False
|