diff options
author | nico <nico@magicbroccoli.de> | 2018-10-06 13:16:27 +0200 |
---|---|---|
committer | nico <nico@magicbroccoli.de> | 2018-10-06 13:16:27 +0200 |
commit | d305f8adf3fa7c4f154f003bdf16ce42b1895ffd (patch) | |
tree | 43095e2fa414b9a92e4ca5081713402f7509df7c /common | |
parent | 6bb9f1d5b87537ed6bccf0dd6efb7b80c6a81395 (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.py | 54 |
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 |