Retrieve database usage

This commit is contained in:
Santiago Lamora 2020-02-17 13:26:07 +01:00
parent 85fc900b6a
commit 7ebe3b61c0
1 changed files with 28 additions and 7 deletions

View File

@ -153,16 +153,37 @@ class DatabaseService(OrchestraModel):
if 'users' in data: if 'users' in data:
users = [DatabaseUser.new_from_json(user_data) for user_data in data['users']] users = [DatabaseUser.new_from_json(user_data) for user_data in data['users']]
# TODO(@slamora) retrieve database usage usage = cls.get_usage(data)
usage = {
'usage': 250,
'total': 500,
'unit': 'MB',
'percent': 50,
}
return super().new_from_json(data=data, users=users, usage=usage) return super().new_from_json(data=data, users=users, usage=usage)
@classmethod
def get_usage(self, data):
try:
resources = data['resources']
resource_disk = {}
for r in resources:
if r['name'] == 'disk':
resource_disk = r
break
details = {
'usage': float(resource_disk['used']),
'total': resource_disk['allocated'],
'unit': resource_disk['unit'],
}
except (IndexError, KeyError):
return {}
percent = get_bootstraped_percent(
details['usage'],
details['total']
)
details['percent'] = percent
return details
class Domain(OrchestraModel): class Domain(OrchestraModel):
api_name = 'domain' api_name = 'domain'