-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmodels.py
40 lines (31 loc) · 1.3 KB
/
models.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
from database import db
class ChordNode(db.Model):
__tablename__ = 'chordnode'
id = db.Column(db.Integer, primary_key=True)
hashed_id = db.Column(db.String)
successor = db.Column(db.String)
predecessor = db.Column(db.String)
is_bootstrap = db.Column(db.Boolean, default=False)
def __repr__(self):
return 'Chord node {}, with successor: {}, predecessor: {}, ' \
'bootstrap: {}'.format(self.hashed_id, self.successor,
self.predecessor, self.is_bootstrap)
class KeyValuePair(db.Model):
__tablename__ = 'keyvaluepair'
id = db.Column(db.Integer, primary_key=True)
chordnode_id = db.Column(db.String)
key = db.Column(db.String)
value = db.Column(db.String)
hashed_key = db.Column(db.String)
replica_id = db.Column(db.Integer)
def __repr__(self):
return "Key-Value pair {}:{}, stored on node {} (replica id: {})".format(
self.key, self.value, self.chordnode_id, self.replica_id)
class NodeRecord(db.Model):
__tablename__ = 'noderecord'
id = db.Column(db.Integer, primary_key=True)
bootstrap_id = db.Column(db.String)
ip_port = db.Column(db.String)
def __repr__(self):
return 'Node record {} on bootstrap node with id {}'.format(self.ip_port,
self.bootstrap_id)