Introduce MongoEngine
Change-Id: Iaad35fa5e1e4134d07c5fb92c60f874a8b77a7f5
This commit is contained in:
parent
cd907a7622
commit
fad7ef331f
@ -13,3 +13,4 @@ pika
|
|||||||
python-surveilclient==0.10.0
|
python-surveilclient==0.10.0
|
||||||
six
|
six
|
||||||
docker-py
|
docker-py
|
||||||
|
mongoengine
|
||||||
|
@ -38,7 +38,9 @@ class BusinessImpactModulationsController(rest.RestController):
|
|||||||
def get_one(self, modulation_name):
|
def get_one(self, modulation_name):
|
||||||
"""Returns a specific business impact modulation."""
|
"""Returns a specific business impact modulation."""
|
||||||
handler = bh.BusinessImpactModulationHandler(pecan.request)
|
handler = bh.BusinessImpactModulationHandler(pecan.request)
|
||||||
modulation = handler.get(modulation_name)
|
modulation = handler.get(
|
||||||
|
{"business_impact_modulation_name": modulation_name}
|
||||||
|
)
|
||||||
return modulation
|
return modulation
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -58,7 +60,9 @@ class BusinessImpactModulationsController(rest.RestController):
|
|||||||
def delete(self, modulation_name):
|
def delete(self, modulation_name):
|
||||||
"""Returns a specific business impact modulation."""
|
"""Returns a specific business impact modulation."""
|
||||||
handler = bh.BusinessImpactModulationHandler(pecan.request)
|
handler = bh.BusinessImpactModulationHandler(pecan.request)
|
||||||
handler.delete(modulation_name)
|
handler.delete(
|
||||||
|
{"business_impact_modulation_name": modulation_name}
|
||||||
|
)
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(mod.BusinessImpactModulation,
|
@wsme_pecan.wsexpose(mod.BusinessImpactModulation,
|
||||||
@ -68,4 +72,7 @@ class BusinessImpactModulationsController(rest.RestController):
|
|||||||
def put(self, modulaion_name, modulation):
|
def put(self, modulaion_name, modulation):
|
||||||
"""Update a specific business impact modulation."""
|
"""Update a specific business impact modulation."""
|
||||||
handler = bh.BusinessImpactModulationHandler(pecan.request)
|
handler = bh.BusinessImpactModulationHandler(pecan.request)
|
||||||
handler.update(modulaion_name, modulation)
|
handler.update(
|
||||||
|
{"business_impact_modulation_name": modulaion_name},
|
||||||
|
modulation
|
||||||
|
)
|
||||||
|
@ -38,7 +38,9 @@ class CheckModulationsController(rest.RestController):
|
|||||||
def get_one(self, checkmodulation_name):
|
def get_one(self, checkmodulation_name):
|
||||||
"""Returns a specific check modulation."""
|
"""Returns a specific check modulation."""
|
||||||
handler = checkmodulation_handler.CheckModulationHandler(pecan.request)
|
handler = checkmodulation_handler.CheckModulationHandler(pecan.request)
|
||||||
checkmodulation = handler.get(checkmodulation_name)
|
checkmodulation = handler.get(
|
||||||
|
{"checkmodulation_name": checkmodulation_name}
|
||||||
|
)
|
||||||
return checkmodulation
|
return checkmodulation
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -57,7 +59,7 @@ class CheckModulationsController(rest.RestController):
|
|||||||
def delete(self, checkmodulation_name):
|
def delete(self, checkmodulation_name):
|
||||||
"""Returns a specific check modulation."""
|
"""Returns a specific check modulation."""
|
||||||
handler = checkmodulation_handler.CheckModulationHandler(pecan.request)
|
handler = checkmodulation_handler.CheckModulationHandler(pecan.request)
|
||||||
handler.delete(checkmodulation_name)
|
handler.delete({"checkmodulation_name": checkmodulation_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(checkmodulation.CheckModulation,
|
@wsme_pecan.wsexpose(checkmodulation.CheckModulation,
|
||||||
@ -67,4 +69,7 @@ class CheckModulationsController(rest.RestController):
|
|||||||
def put(self, checkmodulation_name, checkmodulation):
|
def put(self, checkmodulation_name, checkmodulation):
|
||||||
"""Update a specific check modulation."""
|
"""Update a specific check modulation."""
|
||||||
handler = checkmodulation_handler.CheckModulationHandler(pecan.request)
|
handler = checkmodulation_handler.CheckModulationHandler(pecan.request)
|
||||||
handler.update(checkmodulation_name, checkmodulation)
|
handler.update(
|
||||||
|
{"checkmodulation_name": checkmodulation_name},
|
||||||
|
checkmodulation
|
||||||
|
)
|
@ -32,7 +32,7 @@ class CommandController(rest.RestController):
|
|||||||
def get(self):
|
def get(self):
|
||||||
"""Returns a specific command."""
|
"""Returns a specific command."""
|
||||||
handler = command_handler.CommandHandler(pecan.request)
|
handler = command_handler.CommandHandler(pecan.request)
|
||||||
c = handler.get(self._id)
|
c = handler.get({"command_name": self._id})
|
||||||
return c
|
return c
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -43,14 +43,14 @@ class CommandController(rest.RestController):
|
|||||||
:param data: a command within the request body.
|
:param data: a command within the request body.
|
||||||
"""
|
"""
|
||||||
handler = command_handler.CommandHandler(pecan.request)
|
handler = command_handler.CommandHandler(pecan.request)
|
||||||
handler.update(self._id, data)
|
handler.update({"command_name": self._id}, data)
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(None, status_code=204)
|
@wsme_pecan.wsexpose(None, status_code=204)
|
||||||
def delete(self):
|
def delete(self):
|
||||||
"""Delete this command."""
|
"""Delete this command."""
|
||||||
handler = command_handler.CommandHandler(pecan.request)
|
handler = command_handler.CommandHandler(pecan.request)
|
||||||
handler.delete(self._id)
|
handler.delete({"command_name": self._id})
|
||||||
|
|
||||||
|
|
||||||
class CommandsController(rest.RestController):
|
class CommandsController(rest.RestController):
|
||||||
|
@ -38,7 +38,7 @@ class ContactGroupsController(rest.RestController):
|
|||||||
def get_one(self, group_name):
|
def get_one(self, group_name):
|
||||||
"""Returns a contact group."""
|
"""Returns a contact group."""
|
||||||
handler = contactgroup_handler.ContactGroupHandler(pecan.request)
|
handler = contactgroup_handler.ContactGroupHandler(pecan.request)
|
||||||
contactgroup = handler.get(group_name)
|
contactgroup = handler.get({"contactgroup_name": group_name})
|
||||||
return contactgroup
|
return contactgroup
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -57,7 +57,7 @@ class ContactGroupsController(rest.RestController):
|
|||||||
def delete(self, group_name):
|
def delete(self, group_name):
|
||||||
"""Delete a specific contact group."""
|
"""Delete a specific contact group."""
|
||||||
handler = contactgroup_handler.ContactGroupHandler(pecan.request)
|
handler = contactgroup_handler.ContactGroupHandler(pecan.request)
|
||||||
handler.delete(group_name)
|
handler.delete({"contactgroup_name": group_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(contactgroup.ContactGroup,
|
@wsme_pecan.wsexpose(contactgroup.ContactGroup,
|
||||||
@ -67,4 +67,4 @@ class ContactGroupsController(rest.RestController):
|
|||||||
def put(self, group_name, contactgroup):
|
def put(self, group_name, contactgroup):
|
||||||
"""Update a specific contact group."""
|
"""Update a specific contact group."""
|
||||||
handler = contactgroup_handler.ContactGroupHandler(pecan.request)
|
handler = contactgroup_handler.ContactGroupHandler(pecan.request)
|
||||||
handler.update(group_name, contactgroup)
|
handler.update({"contactgroup_name": group_name}, contactgroup)
|
||||||
|
@ -38,7 +38,7 @@ class ContactsController(rest.RestController):
|
|||||||
def get_one(self, contact_name):
|
def get_one(self, contact_name):
|
||||||
"""Returns a specific contact."""
|
"""Returns a specific contact."""
|
||||||
handler = contact_handler.ContactHandler(pecan.request)
|
handler = contact_handler.ContactHandler(pecan.request)
|
||||||
contact = handler.get(contact_name)
|
contact = handler.get({"contact_name": contact_name})
|
||||||
return contact
|
return contact
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -56,7 +56,7 @@ class ContactsController(rest.RestController):
|
|||||||
def delete(self, contact_name):
|
def delete(self, contact_name):
|
||||||
"""Returns a specific contact."""
|
"""Returns a specific contact."""
|
||||||
handler = contact_handler.ContactHandler(pecan.request)
|
handler = contact_handler.ContactHandler(pecan.request)
|
||||||
handler.delete(contact_name)
|
handler.delete({"contact_name": contact_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(contact.Contact,
|
@wsme_pecan.wsexpose(contact.Contact,
|
||||||
@ -66,4 +66,4 @@ class ContactsController(rest.RestController):
|
|||||||
def put(self, contact_name, contact):
|
def put(self, contact_name, contact):
|
||||||
"""Returns a specific contact."""
|
"""Returns a specific contact."""
|
||||||
handler = contact_handler.ContactHandler(pecan.request)
|
handler = contact_handler.ContactHandler(pecan.request)
|
||||||
handler.update(contact_name, contact)
|
handler.update({"contact_name": contact_name}, contact)
|
||||||
|
@ -38,7 +38,7 @@ class HostGroupsController(rest.RestController):
|
|||||||
def get_one(self, group_name):
|
def get_one(self, group_name):
|
||||||
"""Returns a host group."""
|
"""Returns a host group."""
|
||||||
handler = hostgroup_handler.HostGroupHandler(pecan.request)
|
handler = hostgroup_handler.HostGroupHandler(pecan.request)
|
||||||
hostgroup = handler.get(group_name)
|
hostgroup = handler.get({"hostgroup_name": group_name})
|
||||||
return hostgroup
|
return hostgroup
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -56,7 +56,7 @@ class HostGroupsController(rest.RestController):
|
|||||||
def delete(self, group_name):
|
def delete(self, group_name):
|
||||||
"""Returns a specific host group."""
|
"""Returns a specific host group."""
|
||||||
handler = hostgroup_handler.HostGroupHandler(pecan.request)
|
handler = hostgroup_handler.HostGroupHandler(pecan.request)
|
||||||
handler.delete(group_name)
|
handler.delete({"hostgroup_name": group_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(hostgroup.HostGroup,
|
@wsme_pecan.wsexpose(hostgroup.HostGroup,
|
||||||
@ -66,4 +66,4 @@ class HostGroupsController(rest.RestController):
|
|||||||
def put(self, group_name, hostgroup):
|
def put(self, group_name, hostgroup):
|
||||||
"""Update a specific host group."""
|
"""Update a specific host group."""
|
||||||
handler = hostgroup_handler.HostGroupHandler(pecan.request)
|
handler = hostgroup_handler.HostGroupHandler(pecan.request)
|
||||||
handler.update(group_name, hostgroup)
|
handler.update({"hostgroup_name": group_name}, hostgroup)
|
||||||
|
@ -35,8 +35,12 @@ class HostServiceSubController(rest.RestController):
|
|||||||
"""Returns a specific service."""
|
"""Returns a specific service."""
|
||||||
handler = service_handler.ServiceHandler(pecan.request)
|
handler = service_handler.ServiceHandler(pecan.request)
|
||||||
s = handler.get(
|
s = handler.get(
|
||||||
pecan.request.context['host_name'],
|
{
|
||||||
pecan.request.context['service_description']
|
"host_name": pecan.request.context['host_name'],
|
||||||
|
"service_description": pecan.request.context[
|
||||||
|
'service_description'
|
||||||
|
]
|
||||||
|
}
|
||||||
)
|
)
|
||||||
return s
|
return s
|
||||||
|
|
||||||
@ -46,8 +50,12 @@ class HostServiceSubController(rest.RestController):
|
|||||||
"""Delete a specific service."""
|
"""Delete a specific service."""
|
||||||
handler = service_handler.ServiceHandler(pecan.request)
|
handler = service_handler.ServiceHandler(pecan.request)
|
||||||
handler.delete(
|
handler.delete(
|
||||||
pecan.request.context['host_name'],
|
{
|
||||||
pecan.request.context['service_description']
|
"host_name": pecan.request.context['host_name'],
|
||||||
|
"service_description": pecan.request.context[
|
||||||
|
'service_description'
|
||||||
|
]
|
||||||
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -83,7 +91,7 @@ class HostController(rest.RestController):
|
|||||||
def get(self):
|
def get(self):
|
||||||
"""Returns a specific host."""
|
"""Returns a specific host."""
|
||||||
handler = host_handler.HostHandler(pecan.request)
|
handler = host_handler.HostHandler(pecan.request)
|
||||||
h = handler.get(self._id)
|
h = handler.get({"host_name": self._id})
|
||||||
return h
|
return h
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -94,14 +102,14 @@ class HostController(rest.RestController):
|
|||||||
:param data: a host within the request body.
|
:param data: a host within the request body.
|
||||||
"""
|
"""
|
||||||
handler = host_handler.HostHandler(pecan.request)
|
handler = host_handler.HostHandler(pecan.request)
|
||||||
handler.update(self._id, data)
|
handler.update({"host_name": self._id}, data)
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(None, status_code=204)
|
@wsme_pecan.wsexpose(None, status_code=204)
|
||||||
def delete(self):
|
def delete(self):
|
||||||
"""Delete this host."""
|
"""Delete this host."""
|
||||||
handler = host_handler.HostHandler(pecan.request)
|
handler = host_handler.HostHandler(pecan.request)
|
||||||
handler.delete(self._id)
|
handler.delete({"host_name": self._id})
|
||||||
|
|
||||||
@pecan.expose()
|
@pecan.expose()
|
||||||
def _lookup(self, *remainder):
|
def _lookup(self, *remainder):
|
||||||
@ -120,7 +128,7 @@ class HostsController(rest.RestController):
|
|||||||
"""Returns all hosts."""
|
"""Returns all hosts."""
|
||||||
handler = host_handler.HostHandler(pecan.request)
|
handler = host_handler.HostHandler(pecan.request)
|
||||||
hosts = handler.get_all(
|
hosts = handler.get_all(
|
||||||
templates=bool(templates)
|
exclude_templates=(not bool(templates))
|
||||||
)
|
)
|
||||||
return hosts
|
return hosts
|
||||||
|
|
||||||
|
@ -35,10 +35,12 @@ class MacroModulationController(rest.RestController):
|
|||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(macromodulation.MacroModulation, wtypes.text)
|
@wsme_pecan.wsexpose(macromodulation.MacroModulation, wtypes.text)
|
||||||
def get_one(self, timeperiod_name):
|
def get_one(self, macromodulation_name):
|
||||||
"""Returns a specific macro modulation."""
|
"""Returns a specific macro modulation."""
|
||||||
handler = macromodulation_handler.MacroModulationHandler(pecan.request)
|
handler = macromodulation_handler.MacroModulationHandler(pecan.request)
|
||||||
modulation = handler.get(timeperiod_name)
|
modulation = handler.get(
|
||||||
|
{"macromodulation_name": macromodulation_name}
|
||||||
|
)
|
||||||
return modulation
|
return modulation
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -58,7 +60,7 @@ class MacroModulationController(rest.RestController):
|
|||||||
def delete(self, modulation_name):
|
def delete(self, modulation_name):
|
||||||
"""Returns a specific macro modulation."""
|
"""Returns a specific macro modulation."""
|
||||||
handler = macromodulation_handler.MacroModulationHandler(pecan.request)
|
handler = macromodulation_handler.MacroModulationHandler(pecan.request)
|
||||||
handler.delete(modulation_name)
|
handler.delete({"macromodulation_name": modulation_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(macromodulation.MacroModulation,
|
@wsme_pecan.wsexpose(macromodulation.MacroModulation,
|
||||||
@ -68,4 +70,4 @@ class MacroModulationController(rest.RestController):
|
|||||||
def put(self, modulation_name, modulation):
|
def put(self, modulation_name, modulation):
|
||||||
"""Update a specific macro modulation."""
|
"""Update a specific macro modulation."""
|
||||||
handler = macromodulation_handler.MacroModulationHandler(pecan.request)
|
handler = macromodulation_handler.MacroModulationHandler(pecan.request)
|
||||||
handler.update(modulation_name, modulation)
|
handler.update({"macromodulation_name": modulation_name}, modulation)
|
||||||
|
@ -38,7 +38,9 @@ class NotificationWaysController(rest.RestController):
|
|||||||
def get_one(self, notificationway_name):
|
def get_one(self, notificationway_name):
|
||||||
"""Returns a specific notification way."""
|
"""Returns a specific notification way."""
|
||||||
handler = notificationway_handler.NotificationWayHandler(pecan.request)
|
handler = notificationway_handler.NotificationWayHandler(pecan.request)
|
||||||
notificationway = handler.get(notificationway_name)
|
notificationway = handler.get(
|
||||||
|
{"notificationway_name": notificationway_name}
|
||||||
|
)
|
||||||
return notificationway
|
return notificationway
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -60,7 +62,7 @@ class NotificationWaysController(rest.RestController):
|
|||||||
def delete(self, notificationway_name):
|
def delete(self, notificationway_name):
|
||||||
"""Returns a specific notification way."""
|
"""Returns a specific notification way."""
|
||||||
handler = notificationway_handler.NotificationWayHandler(pecan.request)
|
handler = notificationway_handler.NotificationWayHandler(pecan.request)
|
||||||
handler.delete(notificationway_name)
|
handler.delete({"notificationway_name": notificationway_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(notificationway.NotificationWay,
|
@wsme_pecan.wsexpose(notificationway.NotificationWay,
|
||||||
@ -70,4 +72,7 @@ class NotificationWaysController(rest.RestController):
|
|||||||
def put(self, notificationway_name, notificationway):
|
def put(self, notificationway_name, notificationway):
|
||||||
"""Update a specific notification way."""
|
"""Update a specific notification way."""
|
||||||
handler = notificationway_handler.NotificationWayHandler(pecan.request)
|
handler = notificationway_handler.NotificationWayHandler(pecan.request)
|
||||||
handler.update(notificationway_name, notificationway)
|
handler.update(
|
||||||
|
{"notificationway_name": notificationway_name},
|
||||||
|
notificationway
|
||||||
|
)
|
||||||
|
@ -38,7 +38,7 @@ class RealmsController(rest.RestController):
|
|||||||
def get_one(self, realm_name):
|
def get_one(self, realm_name):
|
||||||
"""Returns a specific realm."""
|
"""Returns a specific realm."""
|
||||||
handler = realm_handler.RealmHandler(pecan.request)
|
handler = realm_handler.RealmHandler(pecan.request)
|
||||||
realm = handler.get(realm_name)
|
realm = handler.get({"realm_name": realm_name})
|
||||||
return realm
|
return realm
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -56,7 +56,7 @@ class RealmsController(rest.RestController):
|
|||||||
def delete(self, realm_name):
|
def delete(self, realm_name):
|
||||||
"""Deletes a specific realm."""
|
"""Deletes a specific realm."""
|
||||||
handler = realm_handler.RealmHandler(pecan.request)
|
handler = realm_handler.RealmHandler(pecan.request)
|
||||||
handler.delete(realm_name)
|
handler.delete({"realm_name": realm_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(realm.Realm,
|
@wsme_pecan.wsexpose(realm.Realm,
|
||||||
@ -66,4 +66,7 @@ class RealmsController(rest.RestController):
|
|||||||
def put(self, realm_name, realm):
|
def put(self, realm_name, realm):
|
||||||
"""Updates a specific realm."""
|
"""Updates a specific realm."""
|
||||||
handler = realm_handler.RealmHandler(pecan.request)
|
handler = realm_handler.RealmHandler(pecan.request)
|
||||||
handler.update(realm_name, realm)
|
handler.update(
|
||||||
|
{"realm_name": realm_name},
|
||||||
|
realm
|
||||||
|
)
|
||||||
|
@ -38,7 +38,7 @@ class ServiceGroupsController(rest.RestController):
|
|||||||
def get_one(self, group_name):
|
def get_one(self, group_name):
|
||||||
"""Returns a service group."""
|
"""Returns a service group."""
|
||||||
handler = servicegroup_handler.ServiceGroupHandler(pecan.request)
|
handler = servicegroup_handler.ServiceGroupHandler(pecan.request)
|
||||||
servicegroup = handler.get(group_name)
|
servicegroup = handler.get({"servicegroup_name": group_name})
|
||||||
return servicegroup
|
return servicegroup
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -57,7 +57,7 @@ class ServiceGroupsController(rest.RestController):
|
|||||||
def delete(self, group_name):
|
def delete(self, group_name):
|
||||||
"""Returns a specific service group."""
|
"""Returns a specific service group."""
|
||||||
handler = servicegroup_handler.ServiceGroupHandler(pecan.request)
|
handler = servicegroup_handler.ServiceGroupHandler(pecan.request)
|
||||||
handler.delete(group_name)
|
handler.delete({"servicegroup_name": group_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(servicegroup.ServiceGroup,
|
@wsme_pecan.wsexpose(servicegroup.ServiceGroup,
|
||||||
@ -67,4 +67,4 @@ class ServiceGroupsController(rest.RestController):
|
|||||||
def put(self, group_name, servicegroup):
|
def put(self, group_name, servicegroup):
|
||||||
"""Update a specific service group."""
|
"""Update a specific service group."""
|
||||||
handler = servicegroup_handler.ServiceGroupHandler(pecan.request)
|
handler = servicegroup_handler.ServiceGroupHandler(pecan.request)
|
||||||
handler.update(group_name, servicegroup)
|
handler.update({"servicegroup_name": group_name}, servicegroup)
|
||||||
|
@ -29,7 +29,7 @@ class ServicesController(rest.RestController):
|
|||||||
"""Returns all services."""
|
"""Returns all services."""
|
||||||
handler = service_handler.ServiceHandler(pecan.request)
|
handler = service_handler.ServiceHandler(pecan.request)
|
||||||
services = handler.get_all(
|
services = handler.get_all(
|
||||||
templates=bool(templates)
|
exclude_templates=(not bool(templates))
|
||||||
)
|
)
|
||||||
return services
|
return services
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ class TimePeriodsController(rest.RestController):
|
|||||||
def get_one(self, timeperiod_name):
|
def get_one(self, timeperiod_name):
|
||||||
"""Returns a specific time period."""
|
"""Returns a specific time period."""
|
||||||
handler = timeperiod_handler.TimePeriodHandler(pecan.request)
|
handler = timeperiod_handler.TimePeriodHandler(pecan.request)
|
||||||
timeperiod = handler.get(timeperiod_name)
|
timeperiod = handler.get({"timeperiod_name": timeperiod_name})
|
||||||
return timeperiod
|
return timeperiod
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@ -56,7 +56,7 @@ class TimePeriodsController(rest.RestController):
|
|||||||
def delete(self, timeperiod_name):
|
def delete(self, timeperiod_name):
|
||||||
"""Returns a specific time period."""
|
"""Returns a specific time period."""
|
||||||
handler = timeperiod_handler.TimePeriodHandler(pecan.request)
|
handler = timeperiod_handler.TimePeriodHandler(pecan.request)
|
||||||
handler.delete(timeperiod_name)
|
handler.delete({"timeperiod_name": timeperiod_name})
|
||||||
|
|
||||||
@util.policy_enforce(['authenticated'])
|
@util.policy_enforce(['authenticated'])
|
||||||
@wsme_pecan.wsexpose(timeperiod.TimePeriod,
|
@wsme_pecan.wsexpose(timeperiod.TimePeriod,
|
||||||
@ -66,4 +66,4 @@ class TimePeriodsController(rest.RestController):
|
|||||||
def put(self, timeperiod_name, timeperiod):
|
def put(self, timeperiod_name, timeperiod):
|
||||||
"""Update a specific time period."""
|
"""Update a specific time period."""
|
||||||
handler = timeperiod_handler.TimePeriodHandler(pecan.request)
|
handler = timeperiod_handler.TimePeriodHandler(pecan.request)
|
||||||
handler.update(timeperiod_name, timeperiod)
|
handler.update({"timeperiod_name": timeperiod_name}, timeperiod)
|
||||||
|
@ -21,33 +21,12 @@ from surveil.api.datamodel import types
|
|||||||
class MacroModulation(types.Base):
|
class MacroModulation(types.Base):
|
||||||
macromodulation_name = wsme.wsattr(wtypes.text, mandatory=True)
|
macromodulation_name = wsme.wsattr(wtypes.text, mandatory=True)
|
||||||
modulation_period = wsme.wsattr(wtypes.text, mandatory=True)
|
modulation_period = wsme.wsattr(wtypes.text, mandatory=True)
|
||||||
# _CRITICAL = wsme.wsattr(int, mandatory=True)
|
|
||||||
# _WARNING = wsme.wsattr(int, mandatory=True)
|
|
||||||
|
|
||||||
macros = wsme.wsattr(
|
macros = wsme.wsattr(
|
||||||
wtypes.DictType(wtypes.text, int),
|
wtypes.DictType(wtypes.text, int),
|
||||||
mandatory=False
|
mandatory=False
|
||||||
)
|
)
|
||||||
|
|
||||||
def __init__(self, **kwargs):
|
|
||||||
super(MacroModulation, self).__init__(**kwargs)
|
|
||||||
|
|
||||||
# Custom fields start with '_'. Detect them and assign them.
|
|
||||||
macros = [i for i in kwargs.items()
|
|
||||||
if isinstance(i[0], str) and i[0].startswith('_')]
|
|
||||||
if len(macros) > 0:
|
|
||||||
self.macros = {}
|
|
||||||
for item in macros:
|
|
||||||
self.macros[item[0]] = item[1]
|
|
||||||
|
|
||||||
def as_dict(self):
|
|
||||||
mod_dict = super(MacroModulation, self).as_dict()
|
|
||||||
macros = mod_dict.pop("macros", None)
|
|
||||||
if macros:
|
|
||||||
for item in macros.items():
|
|
||||||
mod_dict[item[0]] = item[1]
|
|
||||||
return mod_dict
|
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def sample(cls):
|
def sample(cls):
|
||||||
return cls(
|
return cls(
|
||||||
|
@ -27,24 +27,6 @@ class TimePeriod(types.Base):
|
|||||||
mandatory=False
|
mandatory=False
|
||||||
)
|
)
|
||||||
|
|
||||||
def __init__(self, **kwargs):
|
|
||||||
super(TimePeriod, self).__init__(**kwargs)
|
|
||||||
|
|
||||||
periods = [i for i in kwargs.items() if isinstance(i[0], str)
|
|
||||||
and i[0] not in ['timeperiod_name', 'exclude', 'periods']]
|
|
||||||
if len(periods) > 0:
|
|
||||||
self.periods = {}
|
|
||||||
for item in periods:
|
|
||||||
self.periods[item[0]] = item[1]
|
|
||||||
|
|
||||||
def as_dict(self):
|
|
||||||
timeperiod_dict = super(TimePeriod, self).as_dict()
|
|
||||||
periods = timeperiod_dict.pop("periods", None)
|
|
||||||
if periods:
|
|
||||||
for item in periods.items():
|
|
||||||
timeperiod_dict[item[0]] = item[1]
|
|
||||||
return timeperiod_dict
|
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def sample(cls):
|
def sample(cls):
|
||||||
return cls(
|
return cls(
|
||||||
|
@ -12,18 +12,21 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import businessimpactmodulation
|
from surveil.api.datamodel.config import businessimpactmodulation as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import (businessimpactmodulation
|
||||||
|
as storage)
|
||||||
|
|
||||||
|
|
||||||
class BusinessImpactModulationHandler(mongo_object_handler.MongoObjectHandler):
|
class BusinessImpactModulationHandler(
|
||||||
|
mongodb_mongoengine_object_handler.MongoObjectHandler
|
||||||
|
):
|
||||||
"""Fulfills a request on the Business Impact Modulation resource."""
|
"""Fulfills a request on the Business Impact Modulation resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(BusinessImpactModulationHandler, self).__init__(
|
super(BusinessImpactModulationHandler, self).__init__(
|
||||||
'businessimpactmodulations',
|
datamodel.BusinessImpactModulation,
|
||||||
'business_impact_modulation_name',
|
storage.BusinessImpactModulation,
|
||||||
businessimpactmodulation.BusinessImpactModulation,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,20 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import checkmodulation
|
from surveil.api.datamodel.config import checkmodulation as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import checkmodulation as storage
|
||||||
|
|
||||||
|
|
||||||
class CheckModulationHandler(mongo_object_handler.MongoObjectHandler):
|
class CheckModulationHandler(
|
||||||
|
mongodb_mongoengine_object_handler.MongoObjectHandler
|
||||||
|
):
|
||||||
"""Fulfills a request on the Check Modulation resource."""
|
"""Fulfills a request on the Check Modulation resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(CheckModulationHandler, self).__init__(
|
super(CheckModulationHandler, self).__init__(
|
||||||
'checkmodulations',
|
datamodel.CheckModulation,
|
||||||
'checkmodulation_name',
|
storage.CheckModulation,
|
||||||
checkmodulation.CheckModulation,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import command
|
from surveil.api.datamodel.config import command as command_datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import command as command_storage
|
||||||
|
|
||||||
|
|
||||||
class CommandHandler(mongo_object_handler.MongoObjectHandler):
|
class CommandHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the Command resource."""
|
"""Fulfills a request on the Command resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(CommandHandler, self).__init__(
|
super(CommandHandler, self).__init__(
|
||||||
'commands',
|
command_datamodel.Command,
|
||||||
'command_name',
|
command_storage.Command,
|
||||||
command.Command,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import contact
|
from surveil.api.datamodel.config import contact as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import contact as storage
|
||||||
|
|
||||||
|
|
||||||
class ContactHandler(mongo_object_handler.MongoObjectHandler):
|
class ContactHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the Contact resource."""
|
"""Fulfills a request on the Contact resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(ContactHandler, self).__init__(
|
super(ContactHandler, self).__init__(
|
||||||
'contacts',
|
datamodel.Contact,
|
||||||
'contact_name',
|
storage.Contact,
|
||||||
contact.Contact,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,20 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import contactgroup
|
from surveil.api.datamodel.config import contactgroup as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import contactgroup as storage
|
||||||
|
|
||||||
|
|
||||||
class ContactGroupHandler(mongo_object_handler.MongoObjectHandler):
|
class ContactGroupHandler(
|
||||||
|
mongodb_mongoengine_object_handler.MongoObjectHandler
|
||||||
|
):
|
||||||
"""Fulfills a request on the Contact Group resource."""
|
"""Fulfills a request on the Contact Group resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(ContactGroupHandler, self).__init__(
|
super(ContactGroupHandler, self).__init__(
|
||||||
'contactgroups',
|
datamodel.ContactGroup,
|
||||||
'contactgroup_name',
|
storage.ContactGroup,
|
||||||
contactgroup.ContactGroup,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import host
|
from surveil.api.datamodel.config import host as host_datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import host as host_storage
|
||||||
|
|
||||||
|
|
||||||
class HostHandler(mongo_object_handler.MongoObjectHandler):
|
class HostHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the Host resource."""
|
"""Fulfills a request on the Host resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(HostHandler, self).__init__(
|
super(HostHandler, self).__init__(
|
||||||
'hosts',
|
host_datamodel.Host,
|
||||||
'host_name',
|
host_storage.Host,
|
||||||
host.Host,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import hostgroup
|
from surveil.api.datamodel.config import hostgroup as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import hostgroup as storage
|
||||||
|
|
||||||
|
|
||||||
class HostGroupHandler(mongo_object_handler.MongoObjectHandler):
|
class HostGroupHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the host group resource."""
|
"""Fulfills a request on the host group resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(HostGroupHandler, self).__init__(
|
super(HostGroupHandler, self).__init__(
|
||||||
'hostgroups',
|
datamodel.HostGroup,
|
||||||
'hostgroup_name',
|
storage.HostGroup,
|
||||||
hostgroup.HostGroup,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,20 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import macromodulation
|
from surveil.api.datamodel.config import macromodulation as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import macromodulation as storage
|
||||||
|
|
||||||
|
|
||||||
class MacroModulationHandler(mongo_object_handler.MongoObjectHandler):
|
class MacroModulationHandler(
|
||||||
|
mongodb_mongoengine_object_handler.MongoObjectHandler
|
||||||
|
):
|
||||||
"""Fulfills a request on the Macro Modulation resource."""
|
"""Fulfills a request on the Macro Modulation resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(MacroModulationHandler, self).__init__(
|
super(MacroModulationHandler, self).__init__(
|
||||||
'macromodulations',
|
datamodel.MacroModulation,
|
||||||
'macromodulation_name',
|
storage.MacroModulation,
|
||||||
macromodulation.MacroModulation,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,20 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import notificationway
|
from surveil.api.datamodel.config import notificationway as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import notificationway as storage
|
||||||
|
|
||||||
|
|
||||||
class NotificationWayHandler(mongo_object_handler.MongoObjectHandler):
|
class NotificationWayHandler(
|
||||||
|
mongodb_mongoengine_object_handler.MongoObjectHandler
|
||||||
|
):
|
||||||
"""Fulfills a request on the Notification Way resource."""
|
"""Fulfills a request on the Notification Way resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(NotificationWayHandler, self).__init__(
|
super(NotificationWayHandler, self).__init__(
|
||||||
'notificationways',
|
datamodel.NotificationWay,
|
||||||
'notificationway_name',
|
storage.NotificationWays,
|
||||||
notificationway.NotificationWay,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import realm
|
from surveil.api.datamodel.config import realm as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import realm as storage
|
||||||
|
|
||||||
|
|
||||||
class RealmHandler(mongo_object_handler.MongoObjectHandler):
|
class RealmHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the Realm resource."""
|
"""Fulfills a request on the Realm resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(RealmHandler, self).__init__(
|
super(RealmHandler, self).__init__(
|
||||||
'realms',
|
datamodel.Realm,
|
||||||
'realm_name',
|
storage.Realm,
|
||||||
realm.Realm,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,60 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import service
|
from surveil.api.datamodel.config import service as service_datamodel
|
||||||
from surveil.api.handlers import handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import service as service_storage
|
||||||
|
|
||||||
|
|
||||||
class ServiceHandler(handler.Handler):
|
class ServiceHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the service resource."""
|
"""Fulfills a request on the service resource."""
|
||||||
|
|
||||||
def get(self, host_name, service_description):
|
def __init__(self, *args, **kwargs):
|
||||||
"""Return a service."""
|
super(ServiceHandler, self).__init__(
|
||||||
mongo_s = self.request.mongo_connection.shinken.services.find_one(
|
service_datamodel.Service,
|
||||||
{"host_name": host_name,
|
service_storage.Service,
|
||||||
"service_description": service_description}
|
*args,
|
||||||
|
**kwargs
|
||||||
)
|
)
|
||||||
return service.Service(**mongo_s)
|
|
||||||
|
|
||||||
def update(self, id, data):
|
|
||||||
"""Modify existing host."""
|
|
||||||
host_dict = data.as_dict()
|
|
||||||
if "host_name" not in host_dict.keys():
|
|
||||||
host_dict['host_name'] = id
|
|
||||||
|
|
||||||
self.request.mongo_connection.shinken.hosts.update(
|
|
||||||
{"host_name": id},
|
|
||||||
{"$set": host_dict},
|
|
||||||
upsert=True
|
|
||||||
)
|
|
||||||
|
|
||||||
def delete(self, host_name, service_description):
|
|
||||||
"""Delete existing service."""
|
|
||||||
self.request.mongo_connection.shinken.services.remove(
|
|
||||||
{"host_name": host_name,
|
|
||||||
"service_description": service_description}
|
|
||||||
)
|
|
||||||
|
|
||||||
def create(self, data):
|
|
||||||
"""Create a new service."""
|
|
||||||
self.request.mongo_connection.shinken.services.insert(
|
|
||||||
data.as_dict()
|
|
||||||
)
|
|
||||||
|
|
||||||
def get_all(self, host_name=None, templates=False):
|
|
||||||
"""Return all services."""
|
|
||||||
if templates is True:
|
|
||||||
filters = {}
|
|
||||||
else:
|
|
||||||
filters = {"register": {"$ne": "0"}}
|
|
||||||
|
|
||||||
if host_name is not None:
|
|
||||||
filters['host_name'] = host_name
|
|
||||||
|
|
||||||
services = [
|
|
||||||
s for s
|
|
||||||
in self.request.mongo_connection.
|
|
||||||
# Don't return templates
|
|
||||||
shinken.services.find(filters)
|
|
||||||
]
|
|
||||||
return [service.Service(**s) for s in services]
|
|
||||||
|
@ -12,18 +12,20 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import servicegroup
|
from surveil.api.datamodel.config import servicegroup as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import servicegroup as storage
|
||||||
|
|
||||||
|
|
||||||
class ServiceGroupHandler(mongo_object_handler.MongoObjectHandler):
|
class ServiceGroupHandler(
|
||||||
|
mongodb_mongoengine_object_handler.MongoObjectHandler
|
||||||
|
):
|
||||||
"""Fulfills a request on the Service Group resource."""
|
"""Fulfills a request on the Service Group resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(ServiceGroupHandler, self).__init__(
|
super(ServiceGroupHandler, self).__init__(
|
||||||
'servicegroups',
|
datamodel.ServiceGroup,
|
||||||
'servicegroup_name',
|
storage.ServiceGroup,
|
||||||
servicegroup.ServiceGroup,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -12,18 +12,18 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from surveil.api.datamodel.config import timeperiod
|
from surveil.api.datamodel.config import timeperiod as datamodel
|
||||||
from surveil.api.handlers import mongo_object_handler
|
from surveil.api.handlers import mongodb_mongoengine_object_handler
|
||||||
|
from surveil.api.storage.mongodb.config import timeperiod as storage
|
||||||
|
|
||||||
|
|
||||||
class TimePeriodHandler(mongo_object_handler.MongoObjectHandler):
|
class TimePeriodHandler(mongodb_mongoengine_object_handler.MongoObjectHandler):
|
||||||
"""Fulfills a request on the Time Period resource."""
|
"""Fulfills a request on the Time Period resource."""
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(TimePeriodHandler, self).__init__(
|
super(TimePeriodHandler, self).__init__(
|
||||||
'timeperiods',
|
datamodel.TimePeriod,
|
||||||
'timeperiod_name',
|
storage.TimePeriod,
|
||||||
timeperiod.TimePeriod,
|
|
||||||
*args,
|
*args,
|
||||||
**kwargs
|
**kwargs
|
||||||
)
|
)
|
||||||
|
@ -1,80 +0,0 @@
|
|||||||
# Copyright 2014 - Savoir-Faire Linux 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 surveil.api.handlers import handler
|
|
||||||
|
|
||||||
|
|
||||||
class MongoObjectHandler(handler.Handler):
|
|
||||||
"""Fulfills a request on a MongoDB resource."""
|
|
||||||
|
|
||||||
def __init__(self,
|
|
||||||
resource_colleciton,
|
|
||||||
resource_key,
|
|
||||||
resource_datamodel,
|
|
||||||
*args,
|
|
||||||
**kwargs):
|
|
||||||
super(MongoObjectHandler, self).__init__(*args, **kwargs)
|
|
||||||
self.resource_collection = resource_colleciton
|
|
||||||
self.resource_key = resource_key
|
|
||||||
self.resource_datamodel = resource_datamodel
|
|
||||||
|
|
||||||
def _get_resource_collection(self):
|
|
||||||
shinken_db = self.request.mongo_connection.shinken
|
|
||||||
resource_colleciton = getattr(shinken_db, self.resource_collection)
|
|
||||||
return resource_colleciton
|
|
||||||
|
|
||||||
def get(self, resource_key_value):
|
|
||||||
"""Return the resource."""
|
|
||||||
r = self._get_resource_collection().find_one(
|
|
||||||
{self.resource_key: resource_key_value},
|
|
||||||
{'_id': 0}
|
|
||||||
)
|
|
||||||
return self.resource_datamodel(**r)
|
|
||||||
|
|
||||||
def update(self, resource_key_value, resource):
|
|
||||||
"""Modify an existing resource."""
|
|
||||||
resource_dict = resource.as_dict()
|
|
||||||
if self.resource_key not in resource_dict.keys():
|
|
||||||
resource_dict[self.resource_key] = resource_key_value
|
|
||||||
|
|
||||||
self._get_resource_collection().update(
|
|
||||||
{self.resource_key: resource_key_value},
|
|
||||||
{"$set": resource_dict},
|
|
||||||
upsert=True
|
|
||||||
)
|
|
||||||
|
|
||||||
def delete(self, resource_key_value):
|
|
||||||
"""Delete existing resource."""
|
|
||||||
self._get_resource_collection().remove(
|
|
||||||
{self.resource_key: resource_key_value}
|
|
||||||
)
|
|
||||||
|
|
||||||
def create(self, resource):
|
|
||||||
"""Create a new resource."""
|
|
||||||
self._get_resource_collection().insert(
|
|
||||||
resource.as_dict()
|
|
||||||
)
|
|
||||||
|
|
||||||
def get_all(self, templates=False):
|
|
||||||
"""Return all resources."""
|
|
||||||
if templates is True:
|
|
||||||
filters = {}
|
|
||||||
else:
|
|
||||||
filters = {"register": {"$ne": "0"}}
|
|
||||||
|
|
||||||
resources = [r for r
|
|
||||||
in self._get_resource_collection()
|
|
||||||
.find(filters, {'_id': 0})]
|
|
||||||
resources = [self.resource_datamodel(**r) for r in resources]
|
|
||||||
return resources
|
|
75
surveil/api/handlers/mongodb_mongoengine_object_handler.py
Normal file
75
surveil/api/handlers/mongodb_mongoengine_object_handler.py
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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 surveil.api.handlers import handler
|
||||||
|
|
||||||
|
|
||||||
|
class MongoObjectHandler(handler.Handler):
|
||||||
|
"""Fulfills a request on a MongoDB resource."""
|
||||||
|
|
||||||
|
def __init__(self,
|
||||||
|
resource_datamodel,
|
||||||
|
resource_storage,
|
||||||
|
*args,
|
||||||
|
**kwargs):
|
||||||
|
super(MongoObjectHandler, self).__init__(*args, **kwargs)
|
||||||
|
self.resource_datamodel = resource_datamodel
|
||||||
|
self.resource_storage = resource_storage
|
||||||
|
|
||||||
|
def _get_mongoengine_object(self, identifier):
|
||||||
|
return self.resource_storage.objects.get(**identifier)
|
||||||
|
|
||||||
|
def _get_dict(self, mongoengine_object):
|
||||||
|
json_object = mongoengine_object.to_mongo().to_dict()
|
||||||
|
json_object.pop('_id', None)
|
||||||
|
return json_object
|
||||||
|
|
||||||
|
def get(self, identifier):
|
||||||
|
"""Return the resource."""
|
||||||
|
mongoengine_object = self._get_mongoengine_object(identifier)
|
||||||
|
resource_dict = self._get_dict(mongoengine_object)
|
||||||
|
return self.resource_datamodel(**resource_dict)
|
||||||
|
|
||||||
|
def update(self, identifier, resource):
|
||||||
|
"""Modify an existing resource."""
|
||||||
|
r = self._get_mongoengine_object(identifier)
|
||||||
|
resource_dict = resource.as_dict()
|
||||||
|
for key, value in resource_dict.items():
|
||||||
|
setattr(r, key, value)
|
||||||
|
r.save()
|
||||||
|
|
||||||
|
def delete(self, identifier):
|
||||||
|
"""Delete existing resource."""
|
||||||
|
r = self._get_mongoengine_object(identifier)
|
||||||
|
r.delete()
|
||||||
|
r.save()
|
||||||
|
|
||||||
|
def create(self, resource):
|
||||||
|
"""Create a new resource."""
|
||||||
|
r = self.resource_storage(**resource.as_dict())
|
||||||
|
r.save()
|
||||||
|
|
||||||
|
def get_all(self, identifier=None, exclude_templates=False, **kwargs):
|
||||||
|
"""Return all resources."""
|
||||||
|
identifier = identifier or {}
|
||||||
|
if exclude_templates is True:
|
||||||
|
identifier.update(
|
||||||
|
{"register__ne": "0"}
|
||||||
|
)
|
||||||
|
|
||||||
|
return [
|
||||||
|
self.resource_datamodel(**self._get_dict(r))
|
||||||
|
for r
|
||||||
|
in self.resource_storage.objects(**identifier)
|
||||||
|
]
|
0
surveil/api/storage/__init__.py
Normal file
0
surveil/api/storage/__init__.py
Normal file
0
surveil/api/storage/mongodb/__init__.py
Normal file
0
surveil/api/storage/mongodb/__init__.py
Normal file
0
surveil/api/storage/mongodb/config/__init__.py
Normal file
0
surveil/api/storage/mongodb/config/__init__.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class BusinessImpactModulation(mongoengine.Document):
|
||||||
|
meta = {'collection': 'businessimpactmodulations'}
|
||||||
|
business_impact_modulation_name = mongoengine.StringField(unique=True)
|
||||||
|
business_impact = mongoengine.IntField()
|
||||||
|
modulation_period = mongoengine.StringField()
|
22
surveil/api/storage/mongodb/config/checkmodulation.py
Normal file
22
surveil/api/storage/mongodb/config/checkmodulation.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class CheckModulation(mongoengine.Document):
|
||||||
|
meta = {'collection': 'checkmodulations'}
|
||||||
|
checkmodulation_name = mongoengine.StringField(unique=True)
|
||||||
|
check_command = mongoengine.StringField()
|
||||||
|
check_period = mongoengine.StringField()
|
22
surveil/api/storage/mongodb/config/command.py
Normal file
22
surveil/api/storage/mongodb/config/command.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class Command(mongoengine.Document):
|
||||||
|
meta = {'collection': 'commands'}
|
||||||
|
command_name = mongoengine.StringField(unique=True)
|
||||||
|
command_line = mongoengine.StringField()
|
||||||
|
module_type = mongoengine.StringField()
|
35
surveil/api/storage/mongodb/config/contact.py
Normal file
35
surveil/api/storage/mongodb/config/contact.py
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class Contact(mongoengine.Document):
|
||||||
|
meta = {'collection': 'contacts'}
|
||||||
|
contact_name = mongoengine.StringField(unique=True)
|
||||||
|
host_notifications_enabled = mongoengine.StringField()
|
||||||
|
service_notifications_enabled = mongoengine.StringField()
|
||||||
|
host_notification_period = mongoengine.StringField()
|
||||||
|
service_notification_period = mongoengine.StringField()
|
||||||
|
host_notification_options = mongoengine.StringField()
|
||||||
|
service_notification_options = mongoengine.StringField()
|
||||||
|
host_notification_commands = mongoengine.StringField()
|
||||||
|
service_notification_commands = mongoengine.StringField()
|
||||||
|
email = mongoengine.StringField()
|
||||||
|
pager = mongoengine.StringField()
|
||||||
|
can_submit_commands = mongoengine.StringField()
|
||||||
|
is_admin = mongoengine.StringField()
|
||||||
|
retain_status_information = mongoengine.StringField()
|
||||||
|
retain_nonstatus_information = mongoengine.StringField()
|
||||||
|
min_business_impact = mongoengine.StringField()
|
23
surveil/api/storage/mongodb/config/contactgroup.py
Normal file
23
surveil/api/storage/mongodb/config/contactgroup.py
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class ContactGroup(mongoengine.Document):
|
||||||
|
meta = {'collection': 'contactgroups'}
|
||||||
|
contactgroup_name = mongoengine.StringField(unique=True)
|
||||||
|
members = mongoengine.StringField()
|
||||||
|
alias = mongoengine.StringField()
|
||||||
|
contactgroup_members = mongoengine.StringField()
|
33
surveil/api/storage/mongodb/config/host.py
Normal file
33
surveil/api/storage/mongodb/config/host.py
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class Host(mongoengine.Document):
|
||||||
|
meta = {'collection': 'hosts'}
|
||||||
|
host_name = mongoengine.StringField(unique=True)
|
||||||
|
address = mongoengine.StringField()
|
||||||
|
max_check_attempts = mongoengine.IntField()
|
||||||
|
check_period = mongoengine.StringField()
|
||||||
|
contacts = mongoengine.StringField()
|
||||||
|
contact_groups = mongoengine.StringField()
|
||||||
|
notification_interval = mongoengine.IntField()
|
||||||
|
notification_period = mongoengine.StringField()
|
||||||
|
use = mongoengine.StringField()
|
||||||
|
name = mongoengine.StringField()
|
||||||
|
register = mongoengine.StringField()
|
||||||
|
check_interval = mongoengine.IntField()
|
||||||
|
retry_interval = mongoengine.IntField()
|
||||||
|
custom_fields = mongoengine.DictField()
|
26
surveil/api/storage/mongodb/config/hostgroup.py
Normal file
26
surveil/api/storage/mongodb/config/hostgroup.py
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class HostGroup(mongoengine.Document):
|
||||||
|
meta = {'collection': 'hostgroups'}
|
||||||
|
hostgroup_name = mongoengine.StringField(unique=True)
|
||||||
|
members = mongoengine.StringField()
|
||||||
|
alias = mongoengine.StringField()
|
||||||
|
hostgroup_members = mongoengine.StringField()
|
||||||
|
notes = mongoengine.StringField()
|
||||||
|
notes_url = mongoengine.StringField()
|
||||||
|
action_url = mongoengine.StringField()
|
22
surveil/api/storage/mongodb/config/macromodulation.py
Normal file
22
surveil/api/storage/mongodb/config/macromodulation.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class MacroModulation(mongoengine.Document):
|
||||||
|
meta = {'collection': 'macromodulations'}
|
||||||
|
macromodulation_name = mongoengine.StringField(unique=True)
|
||||||
|
modulation_period = mongoengine.StringField()
|
||||||
|
macros = mongoengine.DictField()
|
27
surveil/api/storage/mongodb/config/notificationway.py
Normal file
27
surveil/api/storage/mongodb/config/notificationway.py
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class NotificationWays(mongoengine.Document):
|
||||||
|
meta = {'collection': 'notificationways'}
|
||||||
|
notificationway_name = mongoengine.StringField(unique=True)
|
||||||
|
host_notification_period = mongoengine.StringField()
|
||||||
|
service_notification_period = mongoengine.StringField()
|
||||||
|
host_notification_options = mongoengine.StringField()
|
||||||
|
service_notification_options = mongoengine.StringField()
|
||||||
|
host_notification_commands = mongoengine.StringField()
|
||||||
|
service_notification_commands = mongoengine.StringField()
|
||||||
|
min_business_impact = mongoengine.IntField()
|
22
surveil/api/storage/mongodb/config/realm.py
Normal file
22
surveil/api/storage/mongodb/config/realm.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class Realm(mongoengine.Document):
|
||||||
|
meta = {'collection': 'realms'}
|
||||||
|
realm_name = mongoengine.StringField(unique=True)
|
||||||
|
realm_members = mongoengine.StringField()
|
||||||
|
default = mongoengine.IntField()
|
34
surveil/api/storage/mongodb/config/service.py
Normal file
34
surveil/api/storage/mongodb/config/service.py
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class Service(mongoengine.Document):
|
||||||
|
meta = {'collection': 'services'}
|
||||||
|
host_name = mongoengine.StringField(unique=True)
|
||||||
|
service_description = mongoengine.StringField()
|
||||||
|
contacts = mongoengine.StringField()
|
||||||
|
check_command = mongoengine.StringField()
|
||||||
|
max_check_attempts = mongoengine.IntField()
|
||||||
|
check_interval = mongoengine.IntField()
|
||||||
|
retry_interval = mongoengine.IntField()
|
||||||
|
check_period = mongoengine.StringField()
|
||||||
|
notification_interval = mongoengine.IntField()
|
||||||
|
notification_period = mongoengine.StringField()
|
||||||
|
contact_groups = mongoengine.StringField()
|
||||||
|
passive_checks_enabled = mongoengine.StringField()
|
||||||
|
use = mongoengine.StringField()
|
||||||
|
name = mongoengine.StringField()
|
||||||
|
register = mongoengine.StringField()
|
26
surveil/api/storage/mongodb/config/servicegroup.py
Normal file
26
surveil/api/storage/mongodb/config/servicegroup.py
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class ServiceGroup(mongoengine.Document):
|
||||||
|
meta = {'collection': 'servicegroups'}
|
||||||
|
servicegroup_name = mongoengine.StringField(unique=True)
|
||||||
|
members = mongoengine.StringField()
|
||||||
|
alias = mongoengine.StringField()
|
||||||
|
servicegroup_members = mongoengine.StringField()
|
||||||
|
notes = mongoengine.StringField()
|
||||||
|
notes_url = mongoengine.StringField()
|
||||||
|
action_url = mongoengine.StringField()
|
22
surveil/api/storage/mongodb/config/timeperiod.py
Normal file
22
surveil/api/storage/mongodb/config/timeperiod.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Copyright 2014 - Savoir-Faire Linux 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.
|
||||||
|
|
||||||
|
import mongoengine
|
||||||
|
|
||||||
|
|
||||||
|
class TimePeriod(mongoengine.Document):
|
||||||
|
meta = {'collection': 'timeperiods'}
|
||||||
|
timeperiod_name = mongoengine.StringField(unique=True)
|
||||||
|
exclude = mongoengine.StringField()
|
||||||
|
periods = mongoengine.DictField()
|
@ -30,19 +30,21 @@ class TestHostController(functionalTest.FunctionalTest):
|
|||||||
"max_check_attempts": 5, "check_period": "24x7",
|
"max_check_attempts": 5, "check_period": "24x7",
|
||||||
"contacts": "admin,carl", "contact_groups": "router-admins",
|
"contacts": "admin,carl", "contact_groups": "router-admins",
|
||||||
"notification_interval": 30, "notification_period": "24x7",
|
"notification_interval": 30, "notification_period": "24x7",
|
||||||
|
"custom_fields": {}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"host_name": "bogus-router2", "address": "192.168.1.254",
|
"host_name": "bogus-router2", "address": "192.168.1.254",
|
||||||
"max_check_attempts": 5, "check_period": "24x7",
|
"max_check_attempts": 5, "check_period": "24x7",
|
||||||
"contacts": "admin,carl", "contact_groups": "router-admins",
|
"contacts": "admin,carl", "contact_groups": "router-admins",
|
||||||
"notification_interval": 30, "notification_period": "24x7"
|
"notification_interval": 30, "notification_period": "24x7",
|
||||||
|
"custom_fields": {}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"host_name": "bogus-router333", "address": "192.168.1.254",
|
"host_name": "bogus-router333", "address": "192.168.1.254",
|
||||||
"max_check_attempts": 5, "check_period": "24x7",
|
"max_check_attempts": 5, "check_period": "24x7",
|
||||||
"contacts": "admin,carl", "contact_groups": "router-admins",
|
"contacts": "admin,carl", "contact_groups": "router-admins",
|
||||||
"notification_interval": 30, "notification_period": "24x7",
|
"notification_interval": 30, "notification_period": "24x7",
|
||||||
'use': 'test'
|
'use': 'test', "custom_fields": {}
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
self.mongoconnection.shinken.hosts.insert(
|
self.mongoconnection.shinken.hosts.insert(
|
||||||
@ -80,23 +82,15 @@ class TestHostController(functionalTest.FunctionalTest):
|
|||||||
def test_get_all_hosts_templates(self):
|
def test_get_all_hosts_templates(self):
|
||||||
self.mongoconnection.shinken.hosts.insert(
|
self.mongoconnection.shinken.hosts.insert(
|
||||||
copy.deepcopy(
|
copy.deepcopy(
|
||||||
{"host_name": "bogus-router", "address": "192.168.1.254",
|
{"host_name": "bogus-router345345", "address": "192.168.1.254",
|
||||||
"max_check_attempts": 5, "check_period": "24x7",
|
"max_check_attempts": 5, "check_period": "24x7",
|
||||||
"contacts": "admin,carl", "contact_groups": "router-admins",
|
"contacts": "admin,carl", "contact_groups": "router-admins",
|
||||||
"notification_interval": 30, "notification_period": "24x7",
|
"notification_interval": 30, "notification_period": "24x7",
|
||||||
"register": "0"}
|
"register": "0", "custom_fields": {}}
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
response = self.get('/v2/config/hosts')
|
response = self.get('/v2/config/hosts')
|
||||||
|
|
||||||
# Adjust self.host content to reflect custom_fields sub-dict
|
|
||||||
c_fields = {}
|
|
||||||
for h in self.hosts:
|
|
||||||
if '_CRITICAL' in h.keys():
|
|
||||||
c_fields['_CRITICAL'] = h['_CRITICAL']
|
|
||||||
h.pop('_CRITICAL')
|
|
||||||
h['custom_fields'] = c_fields
|
|
||||||
|
|
||||||
self.assert_count_equal_backport(
|
self.assert_count_equal_backport(
|
||||||
json.loads(response.body.decode()),
|
json.loads(response.body.decode()),
|
||||||
self.hosts
|
self.hosts
|
||||||
@ -143,7 +137,8 @@ class TestHostController(functionalTest.FunctionalTest):
|
|||||||
'contact_groups': u'router-admins',
|
'contact_groups': u'router-admins',
|
||||||
'host_name': u'bogus-router333',
|
'host_name': u'bogus-router333',
|
||||||
'max_check_attempts': 5,
|
'max_check_attempts': 5,
|
||||||
'use': u'test'
|
'use': u'test',
|
||||||
|
'custom_fields': {},
|
||||||
}
|
}
|
||||||
|
|
||||||
self.assertEqual(expected, mongo_host.as_dict())
|
self.assertEqual(expected, mongo_host.as_dict())
|
||||||
@ -167,7 +162,8 @@ class TestHostController(functionalTest.FunctionalTest):
|
|||||||
"contacts": "admin,carl",
|
"contacts": "admin,carl",
|
||||||
"contact_groups": "router-admins",
|
"contact_groups": "router-admins",
|
||||||
"notification_interval": 3,
|
"notification_interval": 3,
|
||||||
"notification_period": "24x7"
|
"notification_period": "24x7",
|
||||||
|
"custom_fields": {}
|
||||||
}
|
}
|
||||||
response = self.post_json("/v2/config/hosts", params=new_host)
|
response = self.post_json("/v2/config/hosts", params=new_host)
|
||||||
|
|
||||||
|
@ -27,14 +27,18 @@ class TestMacroModulationController(functionalTest.FunctionalTest):
|
|||||||
{
|
{
|
||||||
'macromodulation_name': 'HighDuringNight',
|
'macromodulation_name': 'HighDuringNight',
|
||||||
'modulation_period': 'night',
|
'modulation_period': 'night',
|
||||||
'_CRITICAL': 20,
|
'macros': {
|
||||||
'_WARNING': 10,
|
'_CRITICAL': 10,
|
||||||
|
'_WARNING': 20
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'macromodulation_name': 'LowDuringNight',
|
'macromodulation_name': 'LowDuringNight',
|
||||||
'modulation_period': 'night',
|
'modulation_period': 'night',
|
||||||
'_CRITICAL': 10,
|
'macros': {
|
||||||
'_WARNING': 20,
|
'_CRITICAL': 20,
|
||||||
|
'_WARNING': 10
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
self.mongoconnection.shinken.macromodulations.insert(
|
self.mongoconnection.shinken.macromodulations.insert(
|
||||||
@ -50,14 +54,18 @@ class TestMacroModulationController(functionalTest.FunctionalTest):
|
|||||||
'macromodulation_name': 'HighDuringNight',
|
'macromodulation_name': 'HighDuringNight',
|
||||||
'modulation_period': 'night',
|
'modulation_period': 'night',
|
||||||
'macros': {
|
'macros': {
|
||||||
'_CRITICAL': 20,
|
'_CRITICAL': 10,
|
||||||
'_WARNING': 10}},
|
'_WARNING': 20
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
'macromodulation_name': 'LowDuringNight',
|
'macromodulation_name': 'LowDuringNight',
|
||||||
'modulation_period': 'night',
|
'modulation_period': 'night',
|
||||||
'macros': {
|
'macros': {
|
||||||
'_CRITICAL': 10,
|
'_CRITICAL': 20,
|
||||||
'_WARNING': 20}}
|
'_WARNING': 10
|
||||||
|
}
|
||||||
|
}
|
||||||
],
|
],
|
||||||
json.loads(response.body.decode())
|
json.loads(response.body.decode())
|
||||||
|
|
||||||
@ -69,11 +77,14 @@ class TestMacroModulationController(functionalTest.FunctionalTest):
|
|||||||
|
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
json.loads(response.body.decode()),
|
json.loads(response.body.decode()),
|
||||||
{'macromodulation_name': 'HighDuringNight',
|
{
|
||||||
|
'macromodulation_name': 'HighDuringNight',
|
||||||
'modulation_period': 'night',
|
'modulation_period': 'night',
|
||||||
'macros': {
|
'macros': {
|
||||||
'_CRITICAL': 20,
|
'_CRITICAL': 10,
|
||||||
'_WARNING': 10}}
|
'_WARNING': 20
|
||||||
|
}
|
||||||
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
def test_create_macromodulation(self):
|
def test_create_macromodulation(self):
|
||||||
@ -90,11 +101,7 @@ class TestMacroModulationController(functionalTest.FunctionalTest):
|
|||||||
|
|
||||||
self.assertIsNotNone(
|
self.assertIsNotNone(
|
||||||
self.mongoconnection.shinken.macromodulations.find_one(
|
self.mongoconnection.shinken.macromodulations.find_one(
|
||||||
{
|
m
|
||||||
'macromodulation_name': 'TEST_CREATE_MODULATION',
|
|
||||||
'_CRITICAL': 10,
|
|
||||||
'_WARNING': 20
|
|
||||||
}
|
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ class TestServiceController(functionalTest.FunctionalTest):
|
|||||||
def test_get_all_services_templates(self):
|
def test_get_all_services_templates(self):
|
||||||
self.mongoconnection.shinken.services.insert(
|
self.mongoconnection.shinken.services.insert(
|
||||||
copy.deepcopy(
|
copy.deepcopy(
|
||||||
{"host_name": "sample-server3",
|
{"host_name": "sample-server444",
|
||||||
"service_description": "check-disk-sdb",
|
"service_description": "check-disk-sdb",
|
||||||
"check_command": "check-disk!/dev/sdb1",
|
"check_command": "check-disk!/dev/sdb1",
|
||||||
"max_check_attempts": 5,
|
"max_check_attempts": 5,
|
||||||
|
@ -26,13 +26,17 @@ class TestTimePeriodsController(functionalTest.FunctionalTest):
|
|||||||
self.timeperiods = [
|
self.timeperiods = [
|
||||||
{
|
{
|
||||||
'timeperiod_name': 'nonworkhours',
|
'timeperiod_name': 'nonworkhours',
|
||||||
|
"periods": {
|
||||||
'sunday': '00:00-24:00',
|
'sunday': '00:00-24:00',
|
||||||
'monday': '00:00-09:00,17:00-24:00'
|
'monday': '00:00-09:00,17:00-24:00'
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'timeperiod_name': 'misc-single-days',
|
'timeperiod_name': 'misc-single-days',
|
||||||
|
"periods": {
|
||||||
'1999-01-28': '00:00-24:00',
|
'1999-01-28': '00:00-24:00',
|
||||||
'day 2': '00:00-24:00',
|
'day 2': '00:00-24:00',
|
||||||
|
}
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
self.mongoconnection.shinken.timeperiods.insert(
|
self.mongoconnection.shinken.timeperiods.insert(
|
||||||
@ -75,10 +79,7 @@ class TestTimePeriodsController(functionalTest.FunctionalTest):
|
|||||||
self.post_json('/v2/config/timeperiods', t)
|
self.post_json('/v2/config/timeperiods', t)
|
||||||
|
|
||||||
self.assertIsNotNone(
|
self.assertIsNotNone(
|
||||||
self.mongoconnection.shinken.timeperiods.find_one(
|
self.mongoconnection.shinken.timeperiods.find_one(t)
|
||||||
{"timeperiod_name": 'someperiod',
|
|
||||||
"monday": "fun day",
|
|
||||||
"tuesday": "pizza day"})
|
|
||||||
)
|
)
|
||||||
|
|
||||||
def test_delete_timeperiod(self):
|
def test_delete_timeperiod(self):
|
||||||
@ -100,7 +101,7 @@ class TestTimePeriodsController(functionalTest.FunctionalTest):
|
|||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
self.mongoconnection.shinken.timeperiods.find_one(
|
self.mongoconnection.shinken.timeperiods.find_one(
|
||||||
{'timeperiod_name': 'nonworkhours'}
|
{'timeperiod_name': 'nonworkhours'}
|
||||||
)['sunday'],
|
)['periods']['sunday'],
|
||||||
'00:00-24:00'
|
'00:00-24:00'
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -113,6 +114,6 @@ class TestTimePeriodsController(functionalTest.FunctionalTest):
|
|||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
self.mongoconnection.shinken.timeperiods.find_one(
|
self.mongoconnection.shinken.timeperiods.find_one(
|
||||||
{'timeperiod_name': 'nonworkhours'}
|
{'timeperiod_name': 'nonworkhours'}
|
||||||
)['sunday'],
|
)['periods']['sunday'],
|
||||||
'updated'
|
'updated'
|
||||||
)
|
)
|
||||||
|
@ -15,11 +15,13 @@
|
|||||||
import os
|
import os
|
||||||
|
|
||||||
import influxdb
|
import influxdb
|
||||||
|
import mongoengine
|
||||||
import mongomock
|
import mongomock
|
||||||
from oslo_config import cfg
|
from oslo_config import cfg
|
||||||
import pecan
|
import pecan
|
||||||
from pecan import hooks
|
from pecan import hooks
|
||||||
import pecan.testing
|
import pecan.testing
|
||||||
|
import pymongo
|
||||||
|
|
||||||
from surveil.tests import base
|
from surveil.tests import base
|
||||||
|
|
||||||
@ -36,7 +38,14 @@ class FunctionalTest(base.BaseTestCase):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
|
|
||||||
|
if os.environ.get('SURVEIL_FUNCTIONAL_MONGOMOCK', None) == 'True':
|
||||||
self.mongoconnection = mongomock.Connection()
|
self.mongoconnection = mongomock.Connection()
|
||||||
|
else:
|
||||||
|
self.mongoconnection = pymongo.MongoClient()
|
||||||
|
self.mongoconnection.drop_database('shinken')
|
||||||
|
self.mongoconnection.drop_database('alignak_live')
|
||||||
|
self.mongoconnection.drop_database('surveil')
|
||||||
|
|
||||||
self.ws_arbiter_url = "http://localhost:7760"
|
self.ws_arbiter_url = "http://localhost:7760"
|
||||||
self.influxdb_client = influxdb.InfluxDBClient.from_DSN(
|
self.influxdb_client = influxdb.InfluxDBClient.from_DSN(
|
||||||
'influxdb://root:root@influxdb:8086/db'
|
'influxdb://root:root@influxdb:8086/db'
|
||||||
@ -53,6 +62,12 @@ class FunctionalTest(base.BaseTestCase):
|
|||||||
state.request.ws_arbiter_url = self.ws_arbiter_url
|
state.request.ws_arbiter_url = self.ws_arbiter_url
|
||||||
state.request.influxdb_client = self.influxdb_client
|
state.request.influxdb_client = self.influxdb_client
|
||||||
|
|
||||||
|
def get_connection(alias):
|
||||||
|
return self.mongoclient
|
||||||
|
|
||||||
|
mongoengine.connection.get_connection = get_connection
|
||||||
|
mongoengine.connect('shinken')
|
||||||
|
|
||||||
app_hooks = [
|
app_hooks = [
|
||||||
TestHook(
|
TestHook(
|
||||||
self.mongoconnection,
|
self.mongoconnection,
|
||||||
@ -103,4 +118,6 @@ class FunctionalTest(base.BaseTestCase):
|
|||||||
setattr(self, action, make_action(action))
|
setattr(self, action, make_action(action))
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
|
if os.environ.get('SURVEIL_FUNCTIONAL_MONGOMOCK', None) != 'True':
|
||||||
|
self.mongoconnection.close()
|
||||||
pecan.set_config({}, overwrite=True)
|
pecan.set_config({}, overwrite=True)
|
||||||
|
@ -5,7 +5,8 @@ sphinxcontrib-pecanwsme>=0.8
|
|||||||
sphinxcontrib-httpdomain>=1.3.0
|
sphinxcontrib-httpdomain>=1.3.0
|
||||||
oslosphinx>=2.5.0
|
oslosphinx>=2.5.0
|
||||||
testrepository>=0.0.18
|
testrepository>=0.0.18
|
||||||
mongomock
|
#mongomock
|
||||||
|
https://github.com/aviau/mongomock/archive/create_index.zip#egg=mongomock
|
||||||
requests_mock
|
requests_mock
|
||||||
sphinx_rtd_theme
|
sphinx_rtd_theme
|
||||||
docker-compose
|
docker-compose
|
||||||
|
3
tox.ini
3
tox.ini
@ -7,12 +7,13 @@ skipsdist = True
|
|||||||
setenv = LANGUAGE=en_US
|
setenv = LANGUAGE=en_US
|
||||||
LC_ALL=en_US.utf-8
|
LC_ALL=en_US.utf-8
|
||||||
SURVEIL_INTEGRATION_TESTS=False
|
SURVEIL_INTEGRATION_TESTS=False
|
||||||
|
SURVEIL_FUNCTIONAL_MONGOMOCK=False
|
||||||
usedevelop = True
|
usedevelop = True
|
||||||
install_command = pip install -U --force-reinstall {opts} {packages}
|
install_command = pip install -U --force-reinstall {opts} {packages}
|
||||||
deps = -r{toxinidir}/requirements.txt
|
deps = -r{toxinidir}/requirements.txt
|
||||||
-r{toxinidir}/test-requirements.txt
|
-r{toxinidir}/test-requirements.txt
|
||||||
|
|
||||||
commands = python setup.py testr --slowest --testr-args='{posargs}'
|
commands = python setup.py testr --slowest --testr-args='--parallel --concurrency=1'
|
||||||
|
|
||||||
[testenv:integration]
|
[testenv:integration]
|
||||||
setenv = SURVEIL_INTEGRATION_TESTS=True
|
setenv = SURVEIL_INTEGRATION_TESTS=True
|
||||||
|
Loading…
x
Reference in New Issue
Block a user