mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-04 17:22:38 +01:00
e68704a0fc
default required capabilities for topic changes (if topic is +t and user is not an op or halfop), are chan,op and chan,halfop thanks jemfinch for the suggestions.
78 lines
3.9 KiB
Python
78 lines
3.9 KiB
Python
###
|
|
# Copyright (c) 2005, Jeremiah Fincher
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
#
|
|
# * Redistributions of source code must retain the above copyright notice,
|
|
# this list of conditions, and the following disclaimer.
|
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
# this list of conditions, and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
# * Neither the name of the author of this software nor the name of
|
|
# contributors to this software may be used to endorse or promote products
|
|
# derived from this software without specific prior written consent.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
###
|
|
|
|
import supybot.conf as conf
|
|
import supybot.registry as registry
|
|
from supybot.i18n import PluginInternationalization, internationalizeDocstring
|
|
_ = PluginInternationalization('Topic')
|
|
|
|
def configure(advanced):
|
|
# This will be called by supybot to configure this module. advanced is
|
|
# a bool that specifies whether the user identified himself as an advanced
|
|
# user or not. You should effect your configuration by manipulating the
|
|
# registry as appropriate.
|
|
from supybot.questions import expect, anything, something, yn
|
|
conf.registerPlugin('Topic', True)
|
|
|
|
|
|
class TopicFormat(registry.TemplatedString):
|
|
"Value must include $topic, otherwise the actual topic would be left out."
|
|
requiredTemplates = ['topic']
|
|
|
|
Topic = conf.registerPlugin('Topic')
|
|
conf.registerChannelValue(Topic, 'separator',
|
|
registry.StringSurroundedBySpaces(' || ', _("""Determines what separator is
|
|
used between individually added topics in the channel topic.""")))
|
|
conf.registerChannelValue(Topic, 'format',
|
|
TopicFormat('$topic ($nick)', _("""Determines what format is used to add
|
|
topics in the topic. All the standard substitutes apply, in addition to
|
|
"$topic" for the topic itself.""")))
|
|
conf.registerChannelValue(Topic, 'recognizeTopiclen',
|
|
registry.Boolean(True, _("""Determines whether the bot will recognize the
|
|
TOPICLEN value sent to it by the server and thus refuse to send TOPICs
|
|
longer than the TOPICLEN. These topics are likely to be truncated by the
|
|
server anyway, so this defaults to True.""")))
|
|
conf.registerChannelValue(Topic, 'default',
|
|
registry.String('', _("""Determines what the default topic for the channel
|
|
is. This is used by the default command to set this topic.""")))
|
|
conf.registerGroup(Topic, 'undo')
|
|
conf.registerChannelValue(Topic.undo, 'max',
|
|
registry.NonNegativeInteger(10, _("""Determines the number of previous
|
|
topics to keep around in case the undo command is called.""")))
|
|
conf.registerChannelValue(Topic, 'requireManageCapability',
|
|
registry.String('channel,op; channel,halfop', _("""Determines the
|
|
capabilities required (if any) to make any topic changes,
|
|
(everything except for read-only operations). Use 'channel,capab' for
|
|
channel-level capabilities.
|
|
Note that absence of an explicit anticapability means user has
|
|
capability.""")))
|
|
|
|
|
|
# vim:set shiftwidth=4 softtabstop=4 expandtab textwidth=79:
|