Merge pull request #26 from denismakogon/better-logging

Issue #13: Improve logging in controllers
This commit is contained in:
Derek Schultz 2016-12-13 10:07:14 -07:00 committed by GitHub
commit c7f89ebb7e
5 changed files with 188 additions and 96 deletions

View File

@ -38,19 +38,20 @@ class AppV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: successful operation. Return "apps" JSON
description: Successful operation\
"401":
description: Not authorized.
description: Not authorized
"""
c = config.Config.config_instance()
log, fnclient = c.logger, c.functions_client
project_id = request.match_info.get('project_id')
log.info("Listing apps for project: {}".format(project_id))
log.info("[{}] - Listing apps".format(project_id))
stored_apps = await app_model.Apps.find_by(project_id=project_id)
final = []
for app in stored_apps:
fn_app = await fnclient.apps.show(app.name, loop=c.event_loop)
final.append(app_view.AppView(app, fn_app).view())
log.info("[{}] - Apps found: {}".format(project_id, final))
return web.json_response(
data={
self.controller_name: final,
@ -80,9 +81,9 @@ class AppV1Controller(controller.ServiceController):
type: string
responses:
"200":
description: successful operation. Return "app" JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"409":
description: App exists
"""
@ -90,13 +91,15 @@ class AppV1Controller(controller.ServiceController):
log, fnclient = c.logger, c.functions_client
project_id = request.match_info.get('project_id')
data = await request.json()
log.info("Creating an app for project: {} with data {}"
log.info("[{}] - Creating app with data '{}'"
.format(project_id, str(data)))
app_name = "{}-{}".format(
data["app"]["name"],
project_id)[:30]
if await app_model.Apps.exists(app_name, project_id):
log.info("[{}] - Similar app was found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} already exists".format(app_name)
@ -104,13 +107,14 @@ class AppV1Controller(controller.ServiceController):
}, status=409)
fn_app = await fnclient.apps.create(app_name, loop=c.event_loop)
log.debug("[{}] - Fn app created".format(project_id))
stored_app = await app_model.Apps(
name=app_name, project_id=project_id,
description=data["app"].get(
"description",
"App for project {}".format(
project_id))).save()
log.debug("[{}] - App created".format(project_id))
return web.json_response(
data={
"app": app_view.AppView(stored_app, fn_app).view(),
@ -129,9 +133,9 @@ class AppV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: successful operation. Return "app" JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App not found
"""
@ -139,10 +143,12 @@ class AppV1Controller(controller.ServiceController):
log, fnclient = c.logger, c.functions_client
project_id = request.match_info.get('project_id')
app = request.match_info.get('app')
log.info("Requesting an app for project: {} with name {}"
log.info("[{}] - Searching for app with name {}"
.format(project_id, app))
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
@ -151,7 +157,18 @@ class AppV1Controller(controller.ServiceController):
stored_app = (await app_model.Apps.find_by(
project_id=project_id, name=app)).pop()
fn_app = await fnclient.apps.show(app, loop=c.event_loop)
try:
fn_app = await fnclient.apps.show(app, loop=c.event_loop)
log.debug("[{}] - Fn app '{}' found".format(project_id, app))
except Exception as ex:
log.error("[{}] - Fn app '{}' was not found."
"Reason: \n{}".format(project_id, app, str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
}
}, status=getattr(ex, "status", 500))
log.debug("[{}] - App '{}' found".format(project_id, app))
return web.json_response(
data={
"app": app_view.AppView(stored_app, fn_app).view(),
@ -171,29 +188,34 @@ class AppV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: successful operation. Return "app" JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App not found
"""
c = config.Config.config_instance()
log, fnclient = c.logger, c.functions_client
project_id = request.match_info.get('project_id')
app_name = request.match_info.get('app')
data = await request.json()
log.info("[{}] - Setting up update procedure "
"with data '{}'".format(project_id, data))
if not (await app_model.Apps.exists(app_name, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app_name),
}
}, status=404)
c = config.Config.config_instance()
fnclient = c.functions_client
try:
fn_app = await fnclient.apps.update(
app_name, loop=c.event_loop, **data)
except Exception as ex:
log.info("[{}] - Unable to update app, "
"aborting. Reason: \n{}".format(project_id, str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
@ -202,8 +224,8 @@ class AppV1Controller(controller.ServiceController):
stored_app = (await app_model.Apps.find_by(
project_id=project_id, name=app_name)).pop()
c.logger.info("Updating app {} for project: {} with data {}"
.format(app_name, project_id, str(data)))
log.info("[{}] - Updating app {} with data {}"
.format(project_id, app_name, str(data)))
return web.json_response(
data={
"app": app_view.AppView(stored_app, fn_app).view(),
@ -223,27 +245,39 @@ class AppV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: successful operation. Return empty JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App does not exist
description: App not found
"""
project_id = request.match_info.get('project_id')
app = request.match_info.get('app')
c = config.Config.config_instance()
fnclient = c.functions_client
log, fnclient = c.logger, c.functions_client
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
}
}, status=404)
fn_app = await fnclient.apps.show(app, loop=c.event_loop)
fn_app_routes = await fn_app.routes.list(loop=c.event_loop)
try:
fn_app = await fnclient.apps.show(app, loop=c.event_loop)
fn_app_routes = await fn_app.routes.list(loop=c.event_loop)
except Exception as ex:
log.info("[{}] - Unable to get app, "
"aborting. Reason: \n{}".format(project_id, str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
}
}, status=getattr(ex, "status", 500))
if fn_app_routes:
log.info("[{}] - App has routes, unable to delete it, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": ("Unable to delete app {} "
@ -253,8 +287,9 @@ class AppV1Controller(controller.ServiceController):
await app_model.Apps.delete(
project_id=project_id, name=app)
log.debug("[{}] - App model entry gone".format(project_id))
await fnclient.apps.delete(app, loop=c.event_loop)
log.debug("[{}] - Fn app deleted".format(project_id))
return web.json_response(
data={
"message": "App successfully deleted",

View File

@ -41,21 +41,23 @@ class AppRouteV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: Successful operation. Return "routes" JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App does not exist
description: App not found
"""
c = config.Config.config_instance()
log, fnclient = c.logger, c.functions_client
project_id = request.match_info.get('project_id')
app = request.match_info.get('app')
log.info("Listing app {} routes for project: {}."
log.info("[{}] - Listing app '{}' routes"
.format(app, project_id))
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
@ -64,16 +66,16 @@ class AppRouteV1Controller(controller.ServiceController):
fn_app_routes = (await (await fnclient.apps.show(
app, loop=c.event_loop)).routes.list(loop=c.event_loop))
log.debug("[{}] - Fn routes found".format(project_id))
for fn_route in fn_app_routes:
stored_route = (await app_model.Routes.find_by(
app_name=app,
project_id=project_id,
path=fn_route.path)).pop()
log.debug("[{}] - App route '{}' model "
"found".format(project_id, fn_route.path))
setattr(fn_route, "is_public", stored_route.public)
log.info("Listing app {} routes for project: {}."
.format(app, project_id))
return web.json_response(data={
"routes": app_view.AppRouteView(project_id,
app,
@ -109,11 +111,11 @@ class AppRouteV1Controller(controller.ServiceController):
type: boolean
responses:
"200":
description: Successful operation. Return "route" JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App does not exist
description: App not found
"409":
description: App route exists
"""
@ -123,6 +125,8 @@ class AppRouteV1Controller(controller.ServiceController):
app = request.match_info.get('app')
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
@ -137,6 +141,8 @@ class AppRouteV1Controller(controller.ServiceController):
try:
fn_app = await fnclient.apps.show(app, loop=c.event_loop)
except Exception as ex:
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
@ -145,6 +151,9 @@ class AppRouteV1Controller(controller.ServiceController):
try:
await fn_app.routes.show(path, loop=c.event_loop)
log.info("[{}] - Unable to create route. "
"App route '{}' already "
"exists, aborting".format(project_id, path))
return web.json_response(data={
"error": {
"message": (
@ -154,6 +163,8 @@ class AppRouteV1Controller(controller.ServiceController):
}
}, status=409)
except Exception as ex:
log.error("[{}] - Unable to create route. "
"Reason:\n{}".format(project_id, str(ex)))
if getattr(ex, "status", 500) != 404:
return web.json_response(data={
"error": {
@ -161,27 +172,34 @@ class AppRouteV1Controller(controller.ServiceController):
}
}, status=getattr(ex, "status", 500))
new_fn_route = (await fn_app.routes.create(
**data, loop=c.event_loop))
try:
new_fn_route = (await fn_app.routes.create(
**data, loop=c.event_loop))
log.debug("[{}] - Fn app created with data "
"'{}'".format(project_id, str(data)))
stored_route = await app_model.Routes(
app_name=app,
project_id=project_id,
path=new_fn_route.path,
is_public=is_public).save()
stored_route = await app_model.Routes(
app_name=app,
project_id=project_id,
path=new_fn_route.path,
is_public=is_public).save()
log.info("Creating new route in app {} "
"for project: {} with data {}"
.format(app, project_id, str(data)))
setattr(new_fn_route, "is_public", stored_route.public)
view = app_view.AppRouteView(
project_id, app, [new_fn_route]).view_one()
return web.json_response(data={
"route": view,
"message": "App route successfully created"
}, status=200)
setattr(new_fn_route, "is_public", stored_route.public)
view = app_view.AppRouteView(
project_id, app, [new_fn_route]).view_one()
log.info("[{}] - App created with data "
"'{}'".format(project_id, str(view)))
return web.json_response(data={
"route": view,
"message": "App route successfully created"
}, status=200)
except Exception as ex:
log.error("[{}] - Reason:\n{}".format(project_id, str(ex)))
if getattr(ex, "status", 500) != 404:
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
}
}, status=getattr(ex, "status", 500))
@requests.api_action(
method='GET', route='{project_id}/apps/{app}/routes/{route}')
@ -195,13 +213,13 @@ class AppRouteV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: Successful operation. Return "route" JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App does not exist
description: App not found
"404":
description: App route does not exist
description: App route not found
"""
c = config.Config.config_instance()
log, fnclient = c.logger, c.functions_client
@ -210,6 +228,8 @@ class AppRouteV1Controller(controller.ServiceController):
path = request.match_info.get('route')
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
@ -221,14 +241,16 @@ class AppRouteV1Controller(controller.ServiceController):
route = await fn_app.routes.show(
"/{}".format(path), loop=c.event_loop)
except Exception as ex:
log.error("[{}] - Exception while attempting get route info. "
"Reason:\n{}".format(project_id, str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
}
}, status=getattr(ex, "status", 500))
log.info("Requesting route {} in app {} for project: {}"
.format(path, app, project_id))
log.info("[{}] - Requesting route '{}' in app '{}'"
.format(project_id, path, app, ))
stored_route = (await app_model.Routes.find_by(
app_name=app,
@ -237,10 +259,14 @@ class AppRouteV1Controller(controller.ServiceController):
setattr(route, "is_public", stored_route.public)
view = app_view.AppRouteView(
project_id, app, [route]).view_one()
log.info("[{}] - Route found with data "
"'{}'".format(project_id, view))
return web.json_response(data={
"route": app_view.AppRouteView(project_id,
app,
[route]).view_one(),
"route": view,
"message": "App route successfully loaded"
}, status=200)
@ -256,9 +282,9 @@ class AppRouteV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: Successful operation. Return empty JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App does not exist
"404":
@ -274,6 +300,8 @@ class AppRouteV1Controller(controller.ServiceController):
.format(path, app, project_id))
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
@ -285,6 +313,8 @@ class AppRouteV1Controller(controller.ServiceController):
route = await fn_app.routes.update(
"/{}".format(path), loop=c.event_loop, **data)
except Exception as ex:
log.error("[{}] - Unable to update app. "
"Reason:\n{}".format(project_id, str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
@ -298,11 +328,12 @@ class AppRouteV1Controller(controller.ServiceController):
setattr(route, "is_public", stored_route.public)
view = app_view.AppRouteView(
project_id, app, [route]).view_one()
log.info("[{}] - App route update. "
"Route data: {}".format(project_id, view))
return web.json_response(data={
"route": app_view.AppRouteView(project_id,
app,
[route]).view_one(),
"route": view,
"message": "Route successfully updated",
}, status=200)
@ -318,23 +349,25 @@ class AppRouteV1Controller(controller.ServiceController):
- application/json
responses:
"200":
description: Successful operation. Return empty JSON
description: Successful operation
"401":
description: Not authorized.
description: Not authorized
"404":
description: App does not exist
description: App not found
"404":
description: App route does not exist
description: App route not found
"""
c = config.Config.config_instance()
log, fnclient = c.logger, c.functions_client
project_id = request.match_info.get('project_id')
app = request.match_info.get('app')
path = request.match_info.get('route')
log.info("Deleting route {} in app {} for project: {}"
.format(path, app, project_id))
path = "/{}".format(request.match_info.get('route'))
log.info("[{}] - Deleting app '{}' route '{}'"
.format(project_id, app, path))
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),
@ -343,10 +376,12 @@ class AppRouteV1Controller(controller.ServiceController):
try:
fn_app = await fnclient.apps.show(app, loop=c.event_loop)
await fn_app.routes.show("/{}".format(path), loop=c.event_loop)
await fn_app.routes.delete("/{}".format(path), loop=c.event_loop)
await fn_app.routes.show(path, loop=c.event_loop)
await fn_app.routes.delete(path, loop=c.event_loop)
await app_model.Routes.delete(project_id=project_id, app_name=app)
except Exception as ex:
log.error("[{}] - Unable to delete app route '{}'. "
"Reason:\n{}".format(project_id, path, str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),

View File

@ -25,7 +25,7 @@ class RunnableMixin(object):
async def run(self, request, **kwargs):
c = config.Config.config_instance()
fnclient = c.functions_client
log, fnclient = c.logger, c.functions_client
app = request.match_info.get('app')
path = "/{}".format(request.match_info.get('route'))
@ -43,6 +43,8 @@ class RunnableMixin(object):
result = await fn_app.routes.execute(
path, loop=c.event_loop, **data)
except Exception as ex:
log.error("Unable to execute route. "
"Reason:\n{}".format(str(ex)))
return web.json_response(data={
"error": {
"message": getattr(ex, "reason", str(ex)),
@ -82,12 +84,13 @@ class PublicRunnableV1Controller(controller.ServiceController,
- application/json
responses:
"200":
description: successful operation. Return "runnable" JSON
description: Successful operation
"404":
description: App does not exist
description: App not found
"403":
description: Unable to execute private route
"""
log = config.Config.config_instance().logger
app = request.match_info.get('app')
path = "/{}".format(request.match_info.get('route'))
routes = await app_model.Routes.find_by(
@ -102,6 +105,7 @@ class PublicRunnableV1Controller(controller.ServiceController,
route = routes.pop()
if not route.public:
log.info("Unable to execute private route '{}'".format(path))
return web.json_response(data={
"error": {
"message": "Unable to execute private "
@ -132,18 +136,21 @@ class RunnableV1Controller(controller.ServiceController,
- application/json
responses:
"401":
description: Not authorized.
description: Not authorized
"200":
description: successful operation. Return "runnable" JSON
description: Successful operation
"404":
description: App not found
"404":
description: App route not found
"""
log = config.Config.config_instance().logger
app = request.match_info.get('app')
project_id = request.match_info.get('project_id')
if not (await app_model.Apps.exists(app, project_id)):
log.info("[{}] - App not found, "
"aborting".format(project_id))
return web.json_response(data={
"error": {
"message": "App {0} not found".format(app),

View File

@ -28,9 +28,9 @@ class BaseDatabaseModel(object):
def __init__(self, **kwargs):
logger = config.Config.config_instance().logger
logger.info("Attempting to create object class instance "
"'{}' with attributes '{}'"
.format(str(self.__class__), str(kwargs)))
logger.debug("Attempting to create object class instance "
"'{}' with attributes '{}'"
.format(str(self.__class__), str(kwargs)))
self.id = uuid.uuid4().hex
self.created_at = str(datetime.datetime.now())
self.updated_at = str(datetime.datetime.now())
@ -44,13 +44,13 @@ class BaseDatabaseModel(object):
self.table_name,
str(tuple([getattr(self, clmn) for clmn in self.columns]))
)
logger.info("Attempting to save object '{}' "
"using SQL query: {}".format(self.table_name, insert))
logger.debug("Attempting to save object '{}' "
"using SQL query: {}".format(self.table_name, insert))
async with pool.acquire() as conn:
async with conn.cursor() as cur:
await cur.execute(insert)
await conn.commit()
logger.info("Object saved.")
logger.debug("Object saved.")
return self
@classmethod
@ -59,13 +59,13 @@ class BaseDatabaseModel(object):
logger, pool = c.logger, c.connection.pool
delete = cls.DELETE.format(
cls.table_name, cls.__define_where(**kwargs))
logger.info("Attempting to delete object '{}' "
"using SQL query: {}".format(cls.table_name, delete))
logger.debug("Attempting to delete object '{}' "
"using SQL query: {}".format(cls.table_name, delete))
async with pool.acquire() as conn:
async with conn.cursor() as cur:
await cur.execute(delete)
await conn.commit()
logger.info("Object gone.")
logger.debug("Object gone.")
# async def update(self, **kwargs):
# async with config.Connection.from_class().acquire() as conn:
@ -99,8 +99,8 @@ class BaseDatabaseModel(object):
where = cls.__define_where(**kwargs)
select = cls.SELECT.format(
cls.table_name, where)
logger.info("Attempting to find object(s) '{}' "
"using SQL : {}".format(cls.table_name, select))
logger.debug("Attempting to find object(s) '{}' "
"using SQL : {}".format(cls.table_name, select))
async with pool.acquire() as conn:
async with conn.cursor() as cur:
await cur.execute(select)

View File

@ -27,6 +27,15 @@ class Apps(persistence.BaseDatabaseModel):
"name"
)
def __str__(self):
return ("<App name={name} ID={id} "
"description={description} "
"project_id={project_id}>".format(
name=self.name,
description=self.description,
id=self.id,
project_id=self.project_id))
class Routes(persistence.BaseDatabaseModel):
@ -43,3 +52,9 @@ class Routes(persistence.BaseDatabaseModel):
@property
def public(self):
return True if self.is_public else False
def __str__(self):
return ("<App route path={path} project_id={project_id} "
"app={app_name} is_public={is_public} >".format(
path=self.path, project_id=self.project_id,
app_name=self.app_name, is_public=self.public))