PBinCLI/pbincli/utils.py

51 lines
1.5 KiB
Python
Raw Normal View History

2017-03-02 14:23:05 +03:00
import json, os
2017-02-18 21:00:40 +03:00
2017-02-18 21:00:40 +03:00
class PBinCLIException(Exception):
pass
2017-02-18 21:00:40 +03:00
def check_readable(f):
2018-02-12 17:28:18 +03:00
# Checks if path exists and readable
2017-02-18 21:00:40 +03:00
if not os.path.exists(f) or not os.access(f, os.R_OK):
raise PBinCLIException("Error accessing path: {}".format(f))
2017-02-18 21:00:40 +03:00
def check_writable(f):
2018-02-12 17:28:18 +03:00
# Checks if path is writable
2017-02-18 21:00:40 +03:00
if not os.access(os.path.dirname(f) or ".", os.W_OK):
raise PBinCLIException("Path is not writable: {}".format(f))
2017-02-20 15:13:42 +03:00
2018-02-12 17:28:18 +03:00
# http://stackoverflow.com/a/33571117
2017-02-20 15:13:42 +03:00
def json_load_byteified(file_handle):
return _byteify(
json.load(file_handle, object_hook=_byteify),
ignore_dicts=True
)
2017-02-20 15:13:42 +03:00
def json_loads_byteified(json_text):
return _byteify(
json.loads(json_text, object_hook=_byteify),
ignore_dicts=True
)
2017-02-20 15:13:42 +03:00
def _byteify(data, ignore_dicts = False):
# if this is a unicode string, return its string representation
if isinstance(data, str):
2017-02-20 15:13:42 +03:00
return data.encode('utf-8')
# if this is a list of values, return list of byteified values
if isinstance(data, list):
return [ _byteify(item, ignore_dicts=True) for item in data ]
# if this is a dictionary, return dictionary of byteified keys and values
# but only if we haven't already byteified it
if isinstance(data, dict) and not ignore_dicts:
return {
_byteify(key, ignore_dicts=True): _byteify(value, ignore_dicts=True)
for key, value in data.iteritems()
}
# if it's anything else, return it in its original form
return data