mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-04 05:53:43 +00:00 
			
		
		
		
	Move trac integration to a subdirectory.
(imported from commit fea539e275a5c81d9fde7f66ef8396d77f8d8b6d)
This commit is contained in:
		
							
								
								
									
										122
									
								
								api/integrations/trac/humbug_trac.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								api/integrations/trac/humbug_trac.py
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,122 @@
 | 
			
		||||
#!/usr/bin/python
 | 
			
		||||
# -*- coding: utf-8 -*-
 | 
			
		||||
 | 
			
		||||
# Copyright © 2012 Humbug, Inc.
 | 
			
		||||
#
 | 
			
		||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
# of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
# in the Software without restriction, including without limitation the rights
 | 
			
		||||
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
# copies of the Software, and to permit persons to whom the Software is
 | 
			
		||||
# furnished to do so, subject to the following conditions:
 | 
			
		||||
#
 | 
			
		||||
# The above copyright notice and this permission notice shall be included in
 | 
			
		||||
# all copies or substantial portions of the Software.
 | 
			
		||||
#
 | 
			
		||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
# THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Humbug trac plugin -- sends humbugs when tickets change.
 | 
			
		||||
#
 | 
			
		||||
# Install by copying this file and humbug_trac_config.py to the trac
 | 
			
		||||
# plugins/ subdirectory, customizing the constants in
 | 
			
		||||
# humbug_trac_config.py, and then adding "humbug_trac" to the
 | 
			
		||||
# components section of the conf/trac.ini file, like so:
 | 
			
		||||
#
 | 
			
		||||
# [components]
 | 
			
		||||
# humbug_trac = enabled
 | 
			
		||||
#
 | 
			
		||||
# You may then need to restart trac (or restart Apache) for the bot
 | 
			
		||||
# (or changes to the bot) to actually be loaded by trac.
 | 
			
		||||
 | 
			
		||||
from trac.core import Component, implements
 | 
			
		||||
from trac.ticket import ITicketChangeListener
 | 
			
		||||
import sys
 | 
			
		||||
import os.path
 | 
			
		||||
sys.path.insert(0, os.path.dirname(__file__))
 | 
			
		||||
import humbug_trac_config as config
 | 
			
		||||
 | 
			
		||||
if config.HUMBUG_API_PATH is not None:
 | 
			
		||||
    sys.path.append(config.HUMBUG_API_PATH)
 | 
			
		||||
 | 
			
		||||
import humbug
 | 
			
		||||
client = humbug.Client(
 | 
			
		||||
    email=config.HUMBUG_USER,
 | 
			
		||||
    site=config.HUMBUG_SITE,
 | 
			
		||||
    api_key=config.HUMBUG_API_KEY)
 | 
			
		||||
 | 
			
		||||
def markdown_ticket_url(ticket, heading="ticket"):
 | 
			
		||||
    return "[%s #%s](%s/%s)" % (heading, ticket.id, config.TRAC_BASE_TICKET_URL, ticket.id)
 | 
			
		||||
 | 
			
		||||
def markdown_block(desc):
 | 
			
		||||
    return "\n\n>" + "\n> ".join(desc.split("\n")) + "\n"
 | 
			
		||||
 | 
			
		||||
def truncate(string, length):
 | 
			
		||||
    if len(string) <= length:
 | 
			
		||||
        return string
 | 
			
		||||
    return string[:length - 3] + "..."
 | 
			
		||||
 | 
			
		||||
def trac_subject(ticket):
 | 
			
		||||
    return truncate("#%s: %s" % (ticket.id, ticket.values.get("summary")), 60)
 | 
			
		||||
 | 
			
		||||
def send_update(ticket, content):
 | 
			
		||||
    client.send_message({
 | 
			
		||||
            "type": "stream",
 | 
			
		||||
            "to": config.STREAM_FOR_NOTIFICATIONS,
 | 
			
		||||
            "content": content,
 | 
			
		||||
            "subject": trac_subject(ticket)
 | 
			
		||||
            })
 | 
			
		||||
 | 
			
		||||
class HumbugPlugin(Component):
 | 
			
		||||
    implements(ITicketChangeListener)
 | 
			
		||||
 | 
			
		||||
    def ticket_created(self, ticket):
 | 
			
		||||
        """Called when a ticket is created."""
 | 
			
		||||
        content = "%s created %s in component **%s**, priority **%s**:\n" % \
 | 
			
		||||
            (ticket.values.get("reporter"), markdown_ticket_url(ticket),
 | 
			
		||||
             ticket.values.get("component"), ticket.values.get("priority"))
 | 
			
		||||
        if ticket.values.get("description") != "":
 | 
			
		||||
            content += "%s" % markdown_block(ticket.values.get("description"))
 | 
			
		||||
        send_update(ticket, content)
 | 
			
		||||
 | 
			
		||||
    def ticket_changed(self, ticket, comment, author, old_values):
 | 
			
		||||
        """Called when a ticket is modified.
 | 
			
		||||
 | 
			
		||||
        `old_values` is a dictionary containing the previous values of the
 | 
			
		||||
        fields that have changed.
 | 
			
		||||
        """
 | 
			
		||||
        if not (set(old_values.keys()).intersection(set(config.TRAC_NOTIFY_FIELDS)) or
 | 
			
		||||
                (comment and "comment" in set(config.TRAC_NOTIFY_FIELDS))):
 | 
			
		||||
            return
 | 
			
		||||
 | 
			
		||||
        content = "%s updated %s" % (author, markdown_ticket_url(ticket))
 | 
			
		||||
        if comment:
 | 
			
		||||
            content += ' with comment: %s\n\n' % (markdown_block(comment,))
 | 
			
		||||
        else:
 | 
			
		||||
            content += ":\n\n"
 | 
			
		||||
        field_changes = []
 | 
			
		||||
        for key in old_values.keys():
 | 
			
		||||
            if key == "description":
 | 
			
		||||
                content += '- Changed %s from %s to %s' % (key, markdown_block(old_values.get(key)),
 | 
			
		||||
                                                           markdown_block(ticket.values.get(key)))
 | 
			
		||||
            elif old_values.get(key) == "":
 | 
			
		||||
                field_changes.append('%s: => **%s**' % (key, ticket.values.get(key)))
 | 
			
		||||
            elif ticket.values.get(key) == "":
 | 
			
		||||
                field_changes.append('%s: **%s** => ""' % (key, old_values.get(key)))
 | 
			
		||||
            else:
 | 
			
		||||
                field_changes.append('%s: **%s** => **%s**' % (key, old_values.get(key),
 | 
			
		||||
                                                               ticket.values.get(key)))
 | 
			
		||||
        content += ", ".join(field_changes)
 | 
			
		||||
 | 
			
		||||
        send_update(ticket, content)
 | 
			
		||||
 | 
			
		||||
    def ticket_deleted(self, ticket):
 | 
			
		||||
        """Called when a ticket is deleted."""
 | 
			
		||||
        content = "%s was deleted." % markdown_ticket_url(ticket, heading="Ticket")
 | 
			
		||||
        send_update(ticket, content)
 | 
			
		||||
							
								
								
									
										51
									
								
								api/integrations/trac/humbug_trac_config.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								api/integrations/trac/humbug_trac_config.py
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,51 @@
 | 
			
		||||
# -*- coding: utf-8 -*-
 | 
			
		||||
#
 | 
			
		||||
# Copyright © 2012 Humbug, Inc.
 | 
			
		||||
#
 | 
			
		||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
# of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
# in the Software without restriction, including without limitation the rights
 | 
			
		||||
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
# copies of the Software, and to permit persons to whom the Software is
 | 
			
		||||
# furnished to do so, subject to the following conditions:
 | 
			
		||||
#
 | 
			
		||||
# The above copyright notice and this permission notice shall be included in
 | 
			
		||||
# all copies or substantial portions of the Software.
 | 
			
		||||
#
 | 
			
		||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
# THE SOFTWARE.
 | 
			
		||||
 | 
			
		||||
# See humbug_trac.py for installation and configuration instructions
 | 
			
		||||
 | 
			
		||||
# Change these constants to configure the plugin:
 | 
			
		||||
HUMBUG_USER = "trac@example.com"
 | 
			
		||||
HUMBUG_API_KEY = "0123456789abcdef0123456789abcdef"
 | 
			
		||||
STREAM_FOR_NOTIFICATIONS = "trac"
 | 
			
		||||
TRAC_BASE_TICKET_URL = "https://trac.example.com/ticket"
 | 
			
		||||
 | 
			
		||||
# Most people find that having every change in Trac result in a
 | 
			
		||||
# notification is too noisy -- in particular, when someone goes
 | 
			
		||||
# through recategorizing a bunch of tickets, that can often be noisy
 | 
			
		||||
# and annoying.  We solve this issue by only sending a notification
 | 
			
		||||
# for changes to the fields listed below.
 | 
			
		||||
#
 | 
			
		||||
# Total list of possible fields is:
 | 
			
		||||
# (priority, milestone, cc, owner, keywords, component, severity,
 | 
			
		||||
#  type, versions, description, resolution, summary, comment)
 | 
			
		||||
#
 | 
			
		||||
# The following is the list of fields which can be changed without
 | 
			
		||||
# triggering a Humbug notification; change these to match your team's
 | 
			
		||||
# workflow.
 | 
			
		||||
TRAC_NOTIFY_FIELDS = ["description", "summary", "resolution", "comment"]
 | 
			
		||||
 | 
			
		||||
## If properly installed, the Humbug API should be in your import
 | 
			
		||||
## path, but if not, set a custom path below
 | 
			
		||||
HUMBUG_API_PATH = None
 | 
			
		||||
 | 
			
		||||
# This should not need to change unless you have a custom Humbug subdomain.
 | 
			
		||||
HUMBUG_SITE = "https://humbughq.com"
 | 
			
		||||
		Reference in New Issue
	
	Block a user