summaryrefslogtreecommitdiffstats
path: root/common
diff options
context:
space:
mode:
authornico <nico@magicbroccoli.de>2018-10-06 13:16:27 +0200
committernico <nico@magicbroccoli.de>2018-10-06 13:16:27 +0200
commitd305f8adf3fa7c4f154f003bdf16ce42b1895ffd (patch)
tree43095e2fa414b9a92e4ca5081713402f7509df7c /common
parent6bb9f1d5b87537ed6bccf0dd6efb7b80c6a81395 (diff)
small improvements
* leading 0 fix * validation function improvements * moved strings.py and misc files to /common/
Diffstat (limited to 'common')
-rw-r--r--common/strings.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/common/strings.py b/common/strings.py
new file mode 100644
index 0000000..6866a31
--- /dev/null
+++ b/common/strings.py
@@ -0,0 +1,54 @@
+# -*- coding: utf-8 -*-
+from random import randint
+
+
+class StaticAnswers:
+ """
+ collection of callable static/ semi-static strings
+ """
+ def __init__(self, nick=""):
+ self.nickname = nick
+ self.helpfile = {
+ 'help': '!help -- display this text',
+ 'version': '!version domain.tld -- receive XMPP server version',
+ 'uptime': '!uptime domain.tld -- receive XMPP server uptime',
+ 'contact': '!contact domain.tld -- receive XMPP server contact address info',
+ 'xep': '!xep XEP Number -- recieve information about the specified XEP'}
+ self.possible_answers = {
+ '1': 'I heard that, %s.',
+ '2': 'I am sorry for that %s.',
+ '3': '%s did you try turning it off and on again?'}
+ self.error_messages = {
+ '1': 'not reachable',
+ '2': 'not a valid target'
+ }
+ self.keywords = {
+ "keywords": ["!help", "!uptime", "!version", "!contact", "!xep"],
+ "domain_keywords": ["!uptime", "!version", "!contact"],
+ "no_arg_keywords": ["!help"],
+ "number_keywords": ["!xep"]
+ }
+
+ def keys(self, arg="", keyword='keywords'):
+ if arg == 'list':
+ try:
+ return self.keywords[keyword]
+ except KeyError:
+ return self.keywords['keywords']
+ else:
+ return self.keywords
+
+ def gen_help(self):
+ helpdoc = "\n".join(['%s' % value for (_, value) in self.helpfile.items()])
+ return helpdoc
+
+ def gen_answer(self):
+ possible_answers = self.possible_answers
+ return possible_answers[str(randint(1, possible_answers.__len__()))] % self.nickname
+
+ def error(self,code):
+ try:
+ text = self.error_messages[str(code)]
+ except KeyError:
+ return 'unknown error'
+ return text