-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstorage.py
50 lines (45 loc) · 1.81 KB
/
storage.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
import rpyc
import uuid
import os
from rpyc.utils.server import ThreadedServer
DATA_DIR = "/tmp/storage/"
class StorageService(rpyc.Service):
# exposed classes & methods
ALIAES = ["storage"]
def on_connect(self,conn):
print("[+] Client Connected {}".format(conn._channel.stream.sock.getpeername()))
def on_disconnect(self,conn):
print("[+] Client Disconnected {}".format(conn._channel.stream.sock.getpeername()))
class exposed_Storage():
blocks= {}
def exposed_pull(self,uuid):
data_addr = DATA_DIR+str(uuid)
if not os.path.isfile(data_addr):
print("[-] Block not found {}".format(uuid))
return None
with open(data_addr) as f:
return f.read()
def exposed_push(self,data,storages,uuid):
with open(DATA_DIR+str(uuid),'w') as f:
print("[+] Writing data to {}".format(DATA_DIR+str(uuid)))
f.write(data)
if len(storages)>0:
print("[~] Forwarding to other storages")
self.forward(data,storages,uuid)
def exposed_delete(self, uuid):
if os.path.isfile(DATA_DIR+str(uuid)):
print("[+] Removing {}".format(DATA_DIR+str(uuid)))
os.remove(DATA_DIR+str(uuid))
def forward(self,data,storages,uuid):
print "8888: forwarding to:"
print uuid, storages
storage = storages[0]
storages = storages[1:]
host,port = storage
conn = rpyc.connect(host,port=port)
storage = conn.root.Storage()
storage.push(data,storages,uuid)
if __name__ == "__main__":
if not os.path.isdir(DATA_DIR): os.mkdir(DATA_DIR)
t = ThreadedServer(StorageService, port = 8888)
t.start()