2018-01-18 14:53:31 +05:30
|
|
|
# Part of Flectra. See LICENSE file for full copyright and licensing details.
|
|
|
|
|
|
|
|
import logging
|
|
|
|
import werkzeug.wrappers
|
|
|
|
|
|
|
|
try:
|
|
|
|
import simplejson as json
|
|
|
|
except ImportError:
|
|
|
|
import json
|
|
|
|
|
|
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2018-05-30 18:22:42 +05:30
|
|
|
class JSONEncoder(json.JSONEncoder):
|
|
|
|
def default(self, obj):
|
|
|
|
if isinstance(obj, (bytes, bytearray)):
|
|
|
|
return obj.decode("utf-8")
|
|
|
|
return json.JSONEncoder.default(self, obj)
|
|
|
|
|
|
|
|
|
2018-01-18 14:53:31 +05:30
|
|
|
def valid_response(status, data):
|
|
|
|
return werkzeug.wrappers.Response(
|
|
|
|
status=status,
|
|
|
|
content_type='application/json; charset=utf-8',
|
2018-05-30 18:22:42 +05:30
|
|
|
response=json.dumps(data, cls=JSONEncoder),
|
2018-01-18 14:53:31 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def invalid_response(status, error, info):
|
|
|
|
return werkzeug.wrappers.Response(
|
|
|
|
status=status,
|
|
|
|
content_type='application/json; charset=utf-8',
|
|
|
|
response=json.dumps({
|
|
|
|
'error': error,
|
|
|
|
'error_descrip': info,
|
|
|
|
}),
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def invalid_object_id():
|
|
|
|
_logger.error("Invalid object 'id'!")
|
|
|
|
return invalid_response(400, 'invalid_object_id', "Invalid object 'id'!")
|
|
|
|
|
|
|
|
|
|
|
|
def invalid_token():
|
|
|
|
_logger.error("Token is expired or invalid!")
|
|
|
|
return invalid_response(401, 'invalid_token', "Token is expired or invalid!")
|
|
|
|
|
2018-05-30 18:22:42 +05:30
|
|
|
def modal_not_found(modal_name):
|
|
|
|
_logger.error("Not found object(s) in flectra!")
|
|
|
|
return invalid_response(404, 'object_not_found_in_flectra',
|
|
|
|
"Modal " + modal_name + " Not Found!")
|
|
|
|
|
|
|
|
def rest_api_unavailable(modal_name):
|
|
|
|
_logger.error("Not found object(s) in flectra!")
|
|
|
|
return invalid_response(404, 'object_not_found_in_flectra',
|
|
|
|
"Enable Rest API For " + modal_name + "!")
|
|
|
|
|
|
|
|
def object_not_found_all(modal_name):
|
|
|
|
_logger.error("Not found object(s) in flectra!")
|
|
|
|
return invalid_response(404, 'object_not_found_in_flectra',
|
|
|
|
"No Record found in " + modal_name + "!")
|
2018-01-18 14:53:31 +05:30
|
|
|
|
2018-05-30 18:22:42 +05:30
|
|
|
def object_not_found(record_id, modal_name):
|
2018-01-18 14:53:31 +05:30
|
|
|
_logger.error("Not found object(s) in flectra!")
|
2018-05-30 18:22:42 +05:30
|
|
|
return invalid_response(404, 'object_not_found_in_flectra',
|
|
|
|
"Record " + str(record_id) + " Not found in " + modal_name + "!")
|
2018-01-18 14:53:31 +05:30
|
|
|
|
|
|
|
|
|
|
|
def unable_delete():
|
|
|
|
_logger.error("Access Denied!")
|
2018-05-30 18:22:42 +05:30
|
|
|
return invalid_response(403, "you don't have access to delete records for "
|
2018-01-18 14:53:31 +05:30
|
|
|
"this model", "Access Denied!")
|
|
|
|
|
|
|
|
|
|
|
|
def no_object_created(flectra_error):
|
|
|
|
_logger.error("Not created object in flectra! ERROR: %s" % flectra_error)
|
2018-05-30 18:22:42 +05:30
|
|
|
return invalid_response(500, 'not_created_object_in_flectra',
|
2018-01-18 14:53:31 +05:30
|
|
|
"Not created object in flectra! ERROR: %s" %
|
|
|
|
flectra_error)
|
|
|
|
|
|
|
|
|
|
|
|
def no_object_updated(flectra_error):
|
|
|
|
_logger.error("Not updated object in flectra! ERROR: %s" % flectra_error)
|
2018-05-30 18:22:42 +05:30
|
|
|
return invalid_response(500, 'not_updated_object_in_flectra',
|
|
|
|
"Object Not Updated! ERROR: %s" %
|
2018-01-18 14:53:31 +05:30
|
|
|
flectra_error)
|
|
|
|
|
|
|
|
|
|
|
|
def no_object_deleted(flectra_error):
|
|
|
|
_logger.error("Not deleted object in flectra! ERROR: %s" % flectra_error)
|
2018-05-30 18:22:42 +05:30
|
|
|
return invalid_response(500, 'not_deleted_object_in_flectra',
|
2018-01-18 14:53:31 +05:30
|
|
|
"Not deleted object in flectra! ERROR: %s" %
|
|
|
|
flectra_error)
|