Doug Szumski efc6e28edc Fix periodic notifications for webhooks
- Removes the hard-coded magic number of 60 seconds allowing users to
  choose the period that they require.
- Standardise on strings for DictOpt dict keys. When loaded from a config
  file, the DictOpt keys are parsed as strings, which was conflicting with
  the default integer dict keys. This caused the periodic engine to silently
  fail to load when configured via a config file.
- Remove unused variable

Story: 2006783
Task: 37313
Change-Id: Ibd61c45fc1ade37022150d34a5b00c56fdf69814
2019-12-11 11:13:17 +00:00

84 lines
3.5 KiB
Python

# Copyright 2017 FUJITSU LIMITED
#
# 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 oslo_config import cfg
from monasca_notification.conf import types
_DEFAULT_URL = '127.0.0.1:9092'
_DEFAULT_GROUP = 'monasca-notification'
_DEFAULT_ALARM_TOPIC = 'alarm-state-transitions'
_DEFAULT_NOTIFICATION_TOPIC = 'alarm-notifications'
_DEFAULT_RETRY_TOPIC = 'retry-notifications'
_DEFAULT_PERIODIC_TOPICS = {
'60': '60-seconds-notifications'
}
_DEFAULT_MAX_OFFSET_LAG = 600
kafka_group = cfg.OptGroup('kafka',
title='Kafka Options',
help='Options under this group allow to configure '
'valid connection or Kafka queue.')
kafka_opts = [
cfg.ListOpt(name='url', item_type=types.HostAddressPortType(),
bounds=False,
default=_DEFAULT_URL, required=True,
help='List of addresses (with ports) pointing '
'at Kafka cluster.'),
cfg.StrOpt(name='group', default=_DEFAULT_GROUP,
required=True, advanced=True,
help='Consumer\'s group for monasca-notification client.'),
cfg.StrOpt(name='alarm_topic', default=_DEFAULT_ALARM_TOPIC,
required=True, advanced=True,
help='Topic name in kafka where alarm '
'transitions are stored.'),
cfg.StrOpt(name='notification_topic', default=_DEFAULT_NOTIFICATION_TOPIC,
required=True, advanced=True,
help='Topic name in kafka where alarm '
'notifications are stored.'),
cfg.StrOpt(name='notification_retry_topic', default=_DEFAULT_RETRY_TOPIC,
required=True, advanced=True,
help='Topic name in kafka where notifications, that have '
'failed to be sent and are waiting for retry operations, '
'are stored.'),
cfg.DictOpt(name='periodic', default=_DEFAULT_PERIODIC_TOPICS,
required=True, advanced=True,
help='Dict of periodic topics. Keys are the period and '
'values the actual topic names in kafka where '
'notifications are stored.'),
cfg.IntOpt(name='max_offset_lag', default=_DEFAULT_MAX_OFFSET_LAG,
required=True, advanced=True,
help='Maximum lag for topic that is acceptable by '
'the monasca-notification. Notifications that are older '
'than this offset are skipped.'),
cfg.BoolOpt(name='legacy_kafka_client_enabled', default=True,
required=True, advanced=True,
help='Enable legacy Kafka client. When set old version of '
'kafka-python library is used. Message format version '
'for the brokers should be set to 0.9.0.0 to avoid '
'performance issues until all consumers are upgraded.')
]
def register_opts(conf):
conf.register_group(kafka_group)
conf.register_opts(kafka_opts, group=kafka_group)
def list_opts():
return {
kafka_group: kafka_opts
}