From 451c6cae07321163d1a1a2f7006353f165b5e29a Mon Sep 17 00:00:00 2001 From: tahir24434 Date: Mon, 4 Apr 2016 14:42:31 -0700 Subject: [PATCH] Add publisher for syslog Adding syslog publisher to be used by consumers of syslog. Change-Id: I2c6160e786b3cbecb6dae361c98139a754025269 Signed-off-by: tahir24434 --- .../plugins/syslogpublisher.py | 45 +++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 broadview_collector/plugins/syslogpublisher.py diff --git a/broadview_collector/plugins/syslogpublisher.py b/broadview_collector/plugins/syslogpublisher.py new file mode 100644 index 0000000..93f0c70 --- /dev/null +++ b/broadview_collector/plugins/syslogpublisher.py @@ -0,0 +1,45 @@ +# (C) Copyright 2016 PLUMgrid Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# +# You may obtain a copy of the License at +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +from broadviewpublisherbase import BroadViewPublisherBase + +# the Monasca serializer format is suitable for logging output, +# so use it. + +from broadview_collector.serializers.bst_to_monasca import BSTToMonasca +import json +import syslog + +class BroadViewPublisher(BroadViewPublisherBase): + + def __init__(self): + syslog.openlog(ident="BroadView") + + def __del__(self): + syslog.closelog() + + def publish(self, data): + code = 200 + success, sdata = BSTToMonasca().serialize(data) + sdata = json.loads(sdata) + if success: + for x in sdata: + syslog.syslog(json.dumps(x)) + else: + code = 500 + return code + + def __repr__(self): + return "BroadView syslog Publisher" +