1 # -*- coding: utf-8 -*-
2 """Get data from database and publish them."""
4 from random import randint
5 from requests import post
6 from cbconf import Conf
10 """This class connects configuration, database access and publishing."""
13 self.db = Db(self.cfg.getCoffeeDbPath())
17 self.isuff = {1: "st", 2: "nd", 3: "rd", 4: "th", 5: "th"}
24 def sendMsgToSlack(self):
25 """Send message to Slack Bot."""
26 return post(self.cfg.getCoffeebotURL(), dumps({"text": self.msg}))
28 def get_drink_smile(self, drink):
29 """Return Slack smile for ``drink``.
32 drink -- Drink of smile.
36 "espresso": ":coffee:",
37 "espresso lungo": ":coffin:",
38 "cappuccino": ":flara:",
39 "latte macchiato": ":baby_bottle:",
40 "Club-Mate 0,5 l": ":club-mate:",
41 "Club-Mate 0,33 l": ":club-mate_cola:",
45 def getHeroComment(self):
46 """Return comment for hero."""
50 " because couldn't resist",
54 " - superultramaxidrinker",
55 " and didn't sleep last week",
56 " in last 604800 seconds",
58 " and still drinking",
60 ri = randint(0, len(hsuff) - 1)
63 def getSomeSmile(self):
64 """Return some Slack smile."""
74 ri = randint(0, len(smiles) - 1)
77 def computeEqualDrinkers(self):
78 """Compute equally drunken drinkers."""
79 if len(self.top) <= 0:
81 lc = self.top[0][1] + 1
82 for (un, c) in self.top:
86 self.topeq[-1].append((un, c))
89 def loadTopMateDrinkers(self):
90 """Get list of top Mate drinkers, update message."""
91 self.msg = "*Top 5 Club-Mate drinkers*\n"
92 self.top = self.db.getTopMateDrinkers()
93 self.computeEqualDrinkers()
94 totl = [c for (un, c) in self.top]
97 for drinkers in self.topeq[:5]:
99 d = [un for (un, c) in drinkers]
100 self.msg += "{}{}".format(i, self.isuff[i])
107 self.msg += "*{}*".format(un)
109 self.msg += "" if len(d) == 2 else ","
110 self.msg += " and *{}*".format(un)
112 self.msg += ", *{}*".format(un)
114 self.msg += " of whom each drank "
116 self.msg += " who drank "
117 self.msg += "`{:.2f}` liters".format(c)
119 self.msg += self.getHeroComment()
123 self.msg += "Oh, and together we drank *{:.2f}* liters {}".format(
129 def load_top_tea_drinkers(self):
130 """Get list of top tea drinkers, update message."""
131 self.msg = "*Top 5 tea drinkers*\n"
132 self.top = self.db.get_top_tea_drinkers()
133 self.computeEqualDrinkers()
134 tot = sum([c for (un, c) in self.top])
136 for drinkers in self.topeq[:5]:
138 d = [un for (un, c) in drinkers]
139 self.msg += "{}{}".format(i, self.isuff[i])
146 self.msg += "*{}*".format(un)
148 self.msg += "" if len(d) == 2 else ","
149 self.msg += " and *{}*".format(un)
151 self.msg += ", *{}*".format(un)
153 self.msg += " of whom each drank "
155 self.msg += " who drank "
157 self.msg += "`{}` teas".format(c)
159 self.msg += "`{}` tea".format(c)
163 self.msg += "Oh, and together we drank *{}* teas {}".format(
168 def loadDrunkSum(self, *args, **kwargs):
169 """Get list of drunken ``flavor`` from ``dtf`` to ``dtt``, update msg.
172 flavor -- The flavor of beverage.
173 dtf -- Date and time *from*.
174 dtt -- Date and time *to*.
176 self.top = self.db.getDrunkSum(*args, **kwargs)
182 flavor = kwargs["flavor"]
185 self.msg = "{} drunk from {} to {}:\n".format(flavor, dtf, dtt)
186 for (un, cnt) in self.top:
187 self.msg += "{}: {}\n".format(un, cnt)
191 def loadDrunkList(self, *args, **kwargs):
192 """Get list of drunken ``flavor`` from ``dtf`` to ``dtt``, update msg.
195 flavor -- The flavor of beverage.
196 dtf -- Date and time *from*.
197 dtt -- Date and time *to*.
199 self.top = self.db.getDrunkSum(*args, **kwargs)
200 d = self.db.getDrunkList(*args, **kwargs)
206 flavor = kwargs["flavor"]
209 self.msg = "{} drunk from {} to {}:\n".format(flavor, dtf, dtt)
210 for (un, l) in d.items():
211 self.msg += "{}: ".format(un)
213 self.msg += "{}, ".format(cnt)
214 self.msg += "{}\n".format(l[-1])