forked from huntwelch/MongoBot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsql.datastore.py
120 lines (86 loc) · 2.63 KB
/
sql.datastore.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
import mongoengine
from mongoengine import *
from settings import STARTING_CASH
# All mongodb stuff. I've been told this would be
# better done with sqlite. Some day.
def connectdb():
mongoengine.connect('bot', host='localhost')
def simpleupdate(whom, key, val):
try:
drinker = Drinker.objects(name=whom)
if drinker:
drinker = drinker[0]
else:
drinker = Drinker(name=whom)
drinker[key] = val
drinker.save()
except:
return False
return True
def incrementEntity(whom, amount):
try:
entity = Entity.objects(name=whom)
if entity:
entity = entity[0]
else:
entity = Entity(name=whom)
if entity.value:
entity.value = entity.value + amount
else:
entity.value = 0 + amount
except:
return False
entity.save()
return True
def entityScore(whom):
try:
entity = Entity.objects(name=whom)
if entity:
entity = entity[0]
else:
entity = Entity(name=whom)
except:
return 0
return entity.value
def topScores(limit):
return Entity.objects.order_by('-value').limit(limit)
class Entity(Base):
__tablename__ = "entities"
id = Column(Integer, primary_key=True)
name = Column(String)
value = Column(Integer, default=0)
class Position(Base):
__tablename__ = "positions"
symbol = Column(Integer)
date = DateTimeField(required=True)
price = FloatField(min_value=0)
quantity = IntField(min_value=0)
type = StringField()
class Drinker(mongoengine.Document):
name = StringField(required=True)
password = StringField(min_length=40, max_length=40)
company = StringField()
phone = StringField()
rewards = IntField(default=0)
awaiting = StringField()
cash = FloatField(default=STARTING_CASH)
positions = ListField(EmbeddedDocumentField(Position))
class Words(mongoengine.Document):
word = StringField(required=True)
partofspeech = StringField(required=True)
definition = StringField(required=True)
source = StringField(required=True)
class Learned(mongoengine.Document):
word = StringField(required=True)
partofspeech = StringField(required=True)
class Structure(mongoengine.Document):
structure = ListField(StringField())
contents = ListField(StringField())
class Quote(mongoengine.Document):
date = DateTimeField(required=True)
text = StringField(required=True)
adder = StringField(required=True)
random = FloatField()
meta = {
'indexes': ['random', 'text', ('text', 'random')]
}