
Implements: blueprint configurable-notifications Change-Id: I0c808c5e44f9d6092d113bb277c8ab8cf0d69716
198 lines
5.9 KiB
Python
198 lines
5.9 KiB
Python
# Copyright 2017 - Nokia
|
|
#
|
|
# 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.
|
|
import json
|
|
|
|
from oslo_db.sqlalchemy import models
|
|
|
|
from sqlalchemy import Column, DateTime, INTEGER, String, \
|
|
SmallInteger, BigInteger, Index, Boolean, UniqueConstraint
|
|
from sqlalchemy.ext.declarative import declarative_base
|
|
|
|
import sqlalchemy.types as types
|
|
|
|
|
|
class VitrageBase(models.TimestampMixin, models.ModelBase):
|
|
"""Base class for Vitrage Models."""
|
|
__table_args__ = {'mysql_charset': "utf8",
|
|
'mysql_engine': "InnoDB"}
|
|
__table_initialized__ = False
|
|
|
|
def __setitem__(self, key, value):
|
|
setattr(self, key, value)
|
|
|
|
def __getitem__(self, key):
|
|
return getattr(self, key)
|
|
|
|
def update(self, values):
|
|
"""Make the model object behave like a dict."""
|
|
for k, v in values.items():
|
|
setattr(self, k, v)
|
|
|
|
|
|
Base = declarative_base(cls=VitrageBase)
|
|
|
|
|
|
class JSONEncodedDict(types.TypeDecorator):
|
|
"""Represents an immutable structure as a json-encoded string"""
|
|
|
|
impl = types.TEXT
|
|
|
|
def process_bind_param(self, value, dialect):
|
|
if value is not None:
|
|
value = json.dumps(value)
|
|
return value
|
|
|
|
def process_result_value(self, value, dialect):
|
|
if value is not None:
|
|
value = json.loads(value)
|
|
return value
|
|
|
|
|
|
class Event(Base):
|
|
|
|
__tablename__ = 'events'
|
|
|
|
event_id = Column("id", INTEGER, primary_key=True, nullable=False,
|
|
autoincrement=True)
|
|
collector_timestamp = Column(DateTime, index=True, nullable=False)
|
|
payload = Column(JSONEncodedDict(), nullable=False)
|
|
|
|
def __repr__(self):
|
|
return \
|
|
"<Event(" \
|
|
"id='%s', " \
|
|
"collector_timestamp='%s', " \
|
|
"payload='%s')>" % \
|
|
(
|
|
self.event_id,
|
|
self.collector_timestamp,
|
|
self.payload
|
|
)
|
|
|
|
|
|
class ActiveAction(Base, models.TimestampMixin):
|
|
__tablename__ = 'active_actions'
|
|
__table_args__ = (
|
|
# Index 'ix_active_action' on fields:
|
|
# action_type, extra_info, source_vertex_id, target_vertex_id
|
|
Index('ix_active_action', 'action_type', 'extra_info',
|
|
'source_vertex_id', 'target_vertex_id'),
|
|
)
|
|
|
|
action_type = Column(String(128))
|
|
extra_info = Column(String(128))
|
|
source_vertex_id = Column(String(128))
|
|
target_vertex_id = Column(String(128))
|
|
action_id = Column(String(128), primary_key=True)
|
|
score = Column(SmallInteger())
|
|
trigger = Column(BigInteger(), primary_key=True)
|
|
|
|
def __repr__(self):
|
|
return \
|
|
"<ActiveAction(" \
|
|
"created_at='%s', " \
|
|
"action_type='%s', " \
|
|
"extra_info='%s', " \
|
|
"source_vertex_id='%s', " \
|
|
"target_vertex_id='%s', " \
|
|
"action_id='%s', " \
|
|
"score='%s', " \
|
|
"trigger='%s')>" % \
|
|
(
|
|
self.created_at,
|
|
self.action_type,
|
|
self.extra_info,
|
|
self.source_vertex_id,
|
|
self.target_vertex_id,
|
|
self.action_id,
|
|
self.score,
|
|
self.trigger
|
|
)
|
|
|
|
|
|
class GraphSnapshot(Base):
|
|
__tablename__ = 'graph_snapshots'
|
|
|
|
last_event_timestamp = Column(DateTime, primary_key=True, nullable=False)
|
|
graph_snapshot = Column(JSONEncodedDict(), nullable=False)
|
|
|
|
def __repr__(self):
|
|
return \
|
|
"<GraphSnapshot(" \
|
|
"last_event_timestamp='%s', " \
|
|
"graph_snapshot='%s')>" %\
|
|
(
|
|
self.last_event_timestamp,
|
|
self.graph_snapshot
|
|
)
|
|
|
|
|
|
class Template(Base, models.TimestampMixin):
|
|
__tablename__ = 'templates'
|
|
|
|
uuid = Column("id", String(64), primary_key=True, nullable=False)
|
|
status = Column(String(16))
|
|
status_details = Column(String(128))
|
|
name = Column(String(128), nullable=False)
|
|
file_content = Column(JSONEncodedDict, nullable=False)
|
|
template_type = Column("type", String(64), default='standard')
|
|
|
|
def __repr__(self):
|
|
return "<Template(id='%s', name='%s', created_at='%s'," \
|
|
" updated_at='%s', status='%s'," \
|
|
"status_details='%s', file_content='%s', " \
|
|
" template_type='%s' )>" % \
|
|
(self.uuid,
|
|
self.name,
|
|
self.created_at,
|
|
self.updated_at,
|
|
self.status,
|
|
self.status_details,
|
|
self.file_content,
|
|
self.template_type,)
|
|
|
|
|
|
class Webhooks(Base):
|
|
__tablename__ = 'webhooks'
|
|
|
|
id = Column(String(128), primary_key=True)
|
|
project_id = Column(String(128), nullable=False)
|
|
is_admin_webhook = Column(Boolean, nullable=False)
|
|
url = Column(String(256), nullable=False)
|
|
headers = Column(String(1024))
|
|
regex_filter = Column(String(512))
|
|
constraint = UniqueConstraint('url', 'regex_filter')
|
|
|
|
__table_args__ = (UniqueConstraint('url', 'regex_filter'),)
|
|
|
|
def __repr__(self):
|
|
return \
|
|
"<Webhook(" \
|
|
"id='%s', " \
|
|
"created_at='%s', " \
|
|
"project_id='%s', " \
|
|
"is_admin_webhook='%s', " \
|
|
"url='%s', " \
|
|
"headers='%s', " \
|
|
"regex_filter='%s')> " %\
|
|
(
|
|
self.id,
|
|
self.created_at,
|
|
self.project_id,
|
|
self.is_admin_webhook,
|
|
self.url,
|
|
self.headers,
|
|
self.regex_filter
|
|
)
|