8a7d77c180
Change-Id: Icc5b28c4636b542a10502b7b1d2d2dc2028cc166 Signed-off-by: Sorin Sbarnea <ssbarnea@redhat.com>
106 lines
3.8 KiB
Python
106 lines
3.8 KiB
Python
# Copyright 2012 Hewlett-Packard Development Company, L.P.
|
|
#
|
|
# 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.
|
|
|
|
|
|
"""
|
|
The Notifications module allows you to configure Jenkins to notify
|
|
other applications about various build phases. It requires the
|
|
Jenkins notification plugin.
|
|
|
|
**Component**: notifications
|
|
:Macro: notification
|
|
:Entry Point: jenkins_jobs.notifications
|
|
|
|
"""
|
|
|
|
import xml.etree.ElementTree as XML
|
|
|
|
from jenkins_jobs.errors import JenkinsJobsException
|
|
import jenkins_jobs.modules.base
|
|
|
|
|
|
def http_endpoint(registry, xml_parent, data):
|
|
"""yaml: http
|
|
Defines an HTTP notification endpoint.
|
|
Requires the Jenkins :jenkins-wiki:`Notification Plugin
|
|
<Notification+Plugin>`.
|
|
|
|
:arg str format: notification payload format, JSON (default) or XML
|
|
:arg str event: job events that trigger notifications: started,
|
|
completed, finalized or all (default)
|
|
:arg str url: URL of the endpoint
|
|
:arg str timeout: Timeout in milliseconds for sending notification
|
|
request (30 seconds by default)
|
|
:arg str log: Number lines of log messages to send (0 by default).
|
|
Use -1 for all (use with caution).
|
|
|
|
Example:
|
|
|
|
.. literalinclude:: \
|
|
/../../tests/notifications/fixtures/http-endpoint002.yaml
|
|
:language: yaml
|
|
|
|
"""
|
|
endpoint_element = XML.SubElement(xml_parent,
|
|
'com.tikal.hudson.plugins.notification.'
|
|
'Endpoint')
|
|
supported_formats = ['JSON', 'XML']
|
|
fmt = data.get('format', 'JSON').upper()
|
|
if fmt not in supported_formats:
|
|
raise JenkinsJobsException(
|
|
"format must be one of %s" %
|
|
", ".join(supported_formats))
|
|
else:
|
|
XML.SubElement(endpoint_element, 'format').text = fmt
|
|
|
|
XML.SubElement(endpoint_element, 'protocol').text = 'HTTP'
|
|
|
|
supported_events = ['started', 'completed', 'finalized', 'all']
|
|
event = data.get('event', 'all').lower()
|
|
if event not in supported_events:
|
|
raise JenkinsJobsException(
|
|
"event must be one of %s" %
|
|
", ".join(supported_events))
|
|
else:
|
|
XML.SubElement(endpoint_element, 'event').text = event
|
|
|
|
XML.SubElement(endpoint_element, 'timeout').text = str(data.get('timeout',
|
|
30000))
|
|
XML.SubElement(endpoint_element, 'url').text = data['url']
|
|
XML.SubElement(endpoint_element, 'loglines').text = str(data.get('log', 0))
|
|
|
|
|
|
class Notifications(jenkins_jobs.modules.base.Base):
|
|
sequence = 22
|
|
|
|
component_type = 'notification'
|
|
component_list_type = 'notifications'
|
|
|
|
def gen_xml(self, xml_parent, data):
|
|
properties = xml_parent.find('properties')
|
|
if properties is None:
|
|
properties = XML.SubElement(xml_parent, 'properties')
|
|
|
|
notifications = data.get('notifications', [])
|
|
if notifications:
|
|
notify_element = XML.SubElement(properties,
|
|
'com.tikal.hudson.plugins.'
|
|
'notification.'
|
|
'HudsonNotificationProperty')
|
|
endpoints_element = XML.SubElement(notify_element, 'endpoints')
|
|
|
|
for endpoint in notifications:
|
|
self.registry.dispatch('notification',
|
|
endpoints_element, endpoint)
|