Server : Apache System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64 User : palandch ( 1163) PHP Version : 7.1.33 Disable Function : NONE Directory : /opt/cloudlinux/venv/lib64/python3.11/site-packages/clquota/ |
# -*- coding: utf-8 -*- # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2019 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT from __future__ import print_function from __future__ import division from __future__ import absolute_import import json import sys import csv import time from clcommon.ui_config import UIConfig from clcommon import FormattedException def print_text(data, title='id', sort_key=str): ''' Prints data as pure text ''' data_keys = list(data.keys()) if len(data_keys) == 0: return fields = list(map((lambda x: x[0]), data[data_keys[0]])) fmt_list = ['%32s'] fmt_list.extend(['%16s'] * (len(fields))) fmt = ''.join(fmt_list) print(fmt % tuple([title] + fields)) print('-' * 80) for item in sorted(data_keys, key=sort_key): row = [item] row.extend(list(map((lambda x:x[1]), data[item]))) print(fmt % tuple(row)) def print_csv(data, title='id', sort_key=str): ''' Prints data as comma separated values ''' data_keys = list(data.keys()) if len(data_keys) == 0: return fields = list(map((lambda x: x[0]), data[data_keys[0]])) fields = [title] + fields csv_out = csv.writer(sys.stdout, quoting=csv.QUOTE_MINIMAL) fmt = ','.join(['%s'] * len(fields)) print(fmt % tuple(fields)) for item in sorted(data_keys, key=sort_key): row = [item] row.extend(list(map((lambda x:x[1]), data[item]))) csv_out.writerow(row) def print_json(data, title='id', sort_key=str): """ Prints data as json """ print(json.dumps({ 'result': 'success', 'timestamp': time.time(), 'items': data, 'quota_show': check_quota_show(), }, indent=1)) def print_json_error(error): """ Prints error in json format that is later used by cl-limits """ if isinstance(error, FormattedException): print(json.dumps({ 'result': error.message, 'context': error.context, 'details': error.details }, indent=1)) else: print(json.dumps({ 'result': str(error) }, indent=1)) def print_text_error(message): print("ERROR: %s" % (message)) def print_csv_error(message): csv_out = csv.writer(sys.stdout, quoting=csv.QUOTE_ALL) csv_out.writerow(['ERROR', message]) def check_quota_show(): """ Show quota enabled :return: bool """ return UIConfig().get_param('showUserInodesUsage', 'inodeLimits') is True