This repository has been archived by the owner on Oct 17, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.py
128 lines (113 loc) · 6.36 KB
/
config.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
###
# Copyright (c) 2011, Valentin Lorentz
# 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
try:
from supybot.i18n import PluginInternationalization
from supybot.i18n import internationalizeDocstring
_ = PluginInternationalization('Twitter')
except:
# This are useless functions that's allow to run the plugin on a bot
# without the i18n plugin
_ = lambda x:x
internationalizeDocstring = lambda x:x
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('Twitter', True)
Twitter = conf.registerPlugin('Twitter')
# This is where your configuration variables (if any) should go. For example:
# conf.registerGlobalValue(Twitter, 'someConfigVariableName',
# registry.Boolean(False, _("""Help for someConfigVariableName.""")))
conf.registerChannelValue(Twitter, 'prefixusername',
registry.Boolean(True, _("""Determines whether or not the name of the
user posting a tweet will be shown prefixed.""")))
conf.registerGroup(Twitter, 'accounts')
helpGetToken = _('running get_access_token.py is a way to get it')
conf.registerGroup(Twitter, 'consumer')
conf.registerGlobalValue(Twitter.consumer, 'key',
registry.String('bItq1HZhBGyx5Y8ardIeQ',
_("""The consumer key of the application.""")))
conf.registerGlobalValue(Twitter.consumer, 'secret',
registry.String('qjC6Ye6xSMM3XPLR3LLeMqOP4ri0rgoYFT2si1RpY',
_("""The consumer secret of the application."""), private=True))
conf.registerGroup(Twitter.accounts, 'bot')
conf.registerGlobalValue(Twitter.accounts.bot, 'key',
registry.String('', _("""The Twitter Access Token key for the bot's
account (%s)""") % helpGetToken))
conf.registerGlobalValue(Twitter.accounts.bot, 'secret',
registry.String('', _("""The Twitter Access Token secret for the bot's
account (%s)""") % helpGetToken, private=True))
conf.registerGlobalValue(Twitter.accounts.bot, 'api',
registry.String('https://api.twitter.com/1.1', _("""The URL to the
base API URL (by default, it is Twitter.com, but you can use it
for twitter-compatible services, such as identica/statusnet.""")))
conf.registerGroup(Twitter.accounts, 'channel')
conf.registerChannelValue(Twitter.accounts.channel, 'key',
registry.String('', _("""The Twitter Access Token key for this
channel's account (%s)""") % helpGetToken))
conf.registerChannelValue(Twitter.accounts.channel, 'secret',
registry.String('', _("""The Twitter Access Token secret for this
channel's account (%s)""") % helpGetToken, private=True))
conf.registerChannelValue(Twitter.accounts.channel, 'api',
registry.String('https://api.twitter.com/1.1', _("""The URL to the
base API URL (by default, it is Twitter.com, but you can use it
for twitter-compatible services, such as identica/statusnet.""")))
conf.registerGroup(Twitter, 'announce')
conf.registerChannelValue(Twitter.announce, 'interval',
registry.NonNegativeInteger(0, _("""The interval (in seconds) between
two fetches of new tweets from the timeline. 0 (zero) disables this
feature.""")))
conf.registerChannelValue(Twitter.announce, 'withid',
registry.Boolean(True, _("""Determines whether or not the ID of
announced tweets will be displayed.""")))
conf.registerChannelValue(Twitter.announce, 'withshortid',
registry.Boolean(True, _("""Determines whether or not the ID of
announced tweets will be displayed.""")))
conf.registerChannelValue(Twitter.announce, 'oneline',
registry.Boolean(True, _("""Determines whether or not all tweets will
be shown in one line.""")))
conf.registerChannelValue(Twitter.announce, 'retweets',
registry.Boolean(True, _("""Determines whether or not the bot will
show retweets in addition to native tweets.""")))
conf.registerChannelValue(Twitter.announce, 'timeline',
registry.Boolean(True, _("""Determines whether the bot will stream
the timeline of the linked account on the channel (only if
supybot.plugins.Twitter.announce.interval is greater than 0).""")))
conf.registerChannelValue(Twitter.announce, 'mentions',
registry.Boolean(True, _("""Determines whether the bot will stream
mentions to the linked account on the channel (only if
supybot.plugins.Twitter.announce.interval is greater than 0).""")))
conf.registerChannelValue(Twitter.announce, 'users',
registry.SpaceSeparatedListOfStrings([], _("""Determines users whose
tweets will be announced on the channel.""")))
# vim:set shiftwidth=4 tabstop=4 expandtab textwidth=79: