forked from axiom-team/jaklis
Merge cesium+ classes; Create cesium general class to be call with globals methodes
This commit is contained in:
parent
929ea237c5
commit
5476458853
20
jaklis.py
20
jaklis.py
|
@ -5,7 +5,7 @@ from os.path import join, dirname
|
||||||
from shutil import copyfile
|
from shutil import copyfile
|
||||||
from dotenv import load_dotenv
|
from dotenv import load_dotenv
|
||||||
from duniterpy.key import SigningKey
|
from duniterpy.key import SigningKey
|
||||||
from lib.cesium import ReadFromCesium, SendToCesium, DeleteFromCesium, Profiles
|
from lib.cesium import Profiles, CesiumPlus
|
||||||
from lib.likes import ReadLikes, SendLikes, UnLikes
|
from lib.likes import ReadLikes, SendLikes, UnLikes
|
||||||
|
|
||||||
VERSION = "0.0.1"
|
VERSION = "0.0.1"
|
||||||
|
@ -114,10 +114,12 @@ if not os.path.isfile(dunikey):
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
# Build cesiumMessaging class
|
# Construct CesiumPlus object
|
||||||
|
cesium = CesiumPlus(dunikey, pod)
|
||||||
|
|
||||||
|
# Messaging
|
||||||
if cmd == "read":
|
if cmd == "read":
|
||||||
messages = ReadFromCesium(dunikey, pod)
|
cesium.read(args.number, args.outbox, args.json)
|
||||||
messages.read(args.number, args.outbox, args.json)
|
|
||||||
elif cmd == "send":
|
elif cmd == "send":
|
||||||
if args.fichier:
|
if args.fichier:
|
||||||
with open(args.fichier, 'r') as f:
|
with open(args.fichier, 'r') as f:
|
||||||
|
@ -134,14 +136,12 @@ elif cmd == "send":
|
||||||
titre = input("Indiquez le titre du message: ")
|
titre = input("Indiquez le titre du message: ")
|
||||||
msg = input("Indiquez le contenu du message: ")
|
msg = input("Indiquez le contenu du message: ")
|
||||||
|
|
||||||
messages = SendToCesium(dunikey, pod, args.destinataire, args.outbox)
|
cesium.send(titre, msg, args.destinataire, args.outbox)
|
||||||
messages.send(titre, msg)
|
|
||||||
|
|
||||||
elif cmd == "delete":
|
elif cmd == "delete":
|
||||||
messages = DeleteFromCesium(dunikey, pod, args.outbox)
|
cesium.delete(args.id[0], args.outbox)
|
||||||
messages.delete(args.id[0])
|
|
||||||
|
|
||||||
# Build cesium+ profiles class
|
# Profiles
|
||||||
elif cmd in ('set','get','erase'):
|
elif cmd in ('set','get','erase'):
|
||||||
cesium = Profiles(dunikey, pod)
|
cesium = Profiles(dunikey, pod)
|
||||||
if cmd == "set":
|
if cmd == "set":
|
||||||
|
@ -151,7 +151,7 @@ elif cmd in ('set','get','erase'):
|
||||||
elif cmd == "erase":
|
elif cmd == "erase":
|
||||||
cesium.erase()
|
cesium.erase()
|
||||||
|
|
||||||
# Build cesium+ likes class
|
# Likes
|
||||||
elif cmd == "like":
|
elif cmd == "like":
|
||||||
if args.stars or args.stars == 0:
|
if args.stars or args.stars == 0:
|
||||||
gchange = SendLikes(dunikey, pod)
|
gchange = SendLikes(dunikey, pod)
|
||||||
|
|
159
lib/cesium.py
159
lib/cesium.py
|
@ -1,5 +1,3 @@
|
||||||
#!/usr/bin/env python3
|
|
||||||
|
|
||||||
import os, sys, ast, requests, json, base58, base64, time, string, random, re
|
import os, sys, ast, requests, json, base58, base64, time, string, random, re
|
||||||
from lib.natools import fmt, sign, get_privkey, box_decrypt, box_encrypt
|
from lib.natools import fmt, sign, get_privkey, box_decrypt, box_encrypt
|
||||||
from time import sleep
|
from time import sleep
|
||||||
|
@ -17,7 +15,7 @@ def pp_json(json_thing, sort=True, indents=4):
|
||||||
print(json.dumps(json_thing, sort_keys=sort, indent=indents))
|
print(json.dumps(json_thing, sort_keys=sort, indent=indents))
|
||||||
return None
|
return None
|
||||||
|
|
||||||
class ReadFromCesium:
|
class CesiumPlus:
|
||||||
def __init__(self, dunikey, pod):
|
def __init__(self, dunikey, pod):
|
||||||
# Get my pubkey from my private key
|
# Get my pubkey from my private key
|
||||||
try:
|
try:
|
||||||
|
@ -28,13 +26,61 @@ class ReadFromCesium:
|
||||||
sys.stderr.write("Please fill the path to your private key (PubSec)\n")
|
sys.stderr.write("Please fill the path to your private key (PubSec)\n")
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
self.recipient = get_privkey(dunikey, "pubsec").pubkey
|
self.pubkey = get_privkey(dunikey, "pubsec").pubkey
|
||||||
self.pod = pod
|
self.pod = pod
|
||||||
|
|
||||||
if not re.match(PUBKEY_REGEX, self.recipient) or len(self.recipient) > 45:
|
if not re.match(PUBKEY_REGEX, self.pubkey) or len(self.pubkey) > 45:
|
||||||
sys.stderr.write("La clé publique n'est pas au bon format.\n")
|
sys.stderr.write("La clé publique n'est pas au bon format.\n")
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
def signDoc(self, document):
|
||||||
|
# Generate hash of document
|
||||||
|
hashDoc = sha256(document.encode()).hexdigest().upper()
|
||||||
|
|
||||||
|
# Generate signature of document
|
||||||
|
signature = fmt["64"](sign(hashDoc.encode(), get_privkey(self.dunikey, "pubsec"))[:-len(hashDoc.encode())]).decode()
|
||||||
|
|
||||||
|
# Build final document
|
||||||
|
data = {}
|
||||||
|
data['hash'] = hashDoc
|
||||||
|
data['signature'] = signature
|
||||||
|
signJSON = json.dumps(data)
|
||||||
|
finalJSON = {**json.loads(signJSON), **json.loads(document)}
|
||||||
|
finalDoc = json.dumps(finalJSON)
|
||||||
|
|
||||||
|
return finalDoc
|
||||||
|
|
||||||
|
def read(self, nbrMsg, outbox, isJSON):
|
||||||
|
readCesium = ReadFromCesium(self.dunikey, self.pod)
|
||||||
|
jsonMsg = readCesium.sendDocument(nbrMsg, outbox)
|
||||||
|
if isJSON:
|
||||||
|
jsonFormat = readCesium.jsonMessages(jsonMsg, nbrMsg, outbox)
|
||||||
|
print(jsonFormat)
|
||||||
|
else:
|
||||||
|
readCesium.readMessages(jsonMsg, nbrMsg, outbox)
|
||||||
|
|
||||||
|
def send(self, title, msg, recipient, outbox):
|
||||||
|
sendCesium = SendToCesium(self.dunikey, self.pod)
|
||||||
|
sendCesium.recipient = recipient
|
||||||
|
|
||||||
|
# Generate pseudo-random nonce
|
||||||
|
nonce=[]
|
||||||
|
for _ in range(32):
|
||||||
|
nonce.append(random.choice(string.ascii_letters + string.digits))
|
||||||
|
sendCesium.nonce = base64.b64decode(''.join(nonce))
|
||||||
|
|
||||||
|
finalDoc = sendCesium.configDoc(sendCesium.encryptMsg(title), sendCesium.encryptMsg(msg)) # Configure JSON document to send
|
||||||
|
sendCesium.sendDocument(finalDoc, outbox) # Send final signed document
|
||||||
|
|
||||||
|
def delete(self, idsMsgList, outbox):
|
||||||
|
deleteCesium = DeleteFromCesium(self.dunikey, self.pod)
|
||||||
|
# deleteCesium.issuer = recipient
|
||||||
|
for idMsg in idsMsgList:
|
||||||
|
finalDoc = deleteCesium.configDoc(idMsg, outbox)
|
||||||
|
deleteCesium.sendDocument(finalDoc, idMsg)
|
||||||
|
|
||||||
|
|
||||||
|
class ReadFromCesium(CesiumPlus):
|
||||||
# Configure JSON document to send
|
# Configure JSON document to send
|
||||||
def configDoc(self, nbrMsg, outbox):
|
def configDoc(self, nbrMsg, outbox):
|
||||||
boxType = "issuer" if outbox else "recipient"
|
boxType = "issuer" if outbox else "recipient"
|
||||||
|
@ -48,7 +94,7 @@ class ReadFromCesium:
|
||||||
data['query']['bool'] = {}
|
data['query']['bool'] = {}
|
||||||
data['query']['bool']['filter'] = {}
|
data['query']['bool']['filter'] = {}
|
||||||
data['query']['bool']['filter']['term'] = {}
|
data['query']['bool']['filter']['term'] = {}
|
||||||
data['query']['bool']['filter']['term'][boxType] = self.recipient
|
data['query']['bool']['filter']['term'][boxType] = self.pubkey
|
||||||
|
|
||||||
document = json.dumps(data)
|
document = json.dumps(data)
|
||||||
return document
|
return document
|
||||||
|
@ -116,7 +162,7 @@ class ReadFromCesium:
|
||||||
|
|
||||||
print(colored(infoTotal.center(rows, '#'), "yellow"))
|
print(colored(infoTotal.center(rows, '#'), "yellow"))
|
||||||
|
|
||||||
# Parse JSON result and display messages
|
# Parse JSON result and display messages
|
||||||
def jsonMessages(self, msgJSON, nbrMsg, outbox):
|
def jsonMessages(self, msgJSON, nbrMsg, outbox):
|
||||||
def decrypt(msg):
|
def decrypt(msg):
|
||||||
msg64 = base64.b64decode(msg)
|
msg64 = base64.b64decode(msg)
|
||||||
|
@ -165,13 +211,6 @@ class ReadFromCesium:
|
||||||
data = json.dumps(data, indent=2)
|
data = json.dumps(data, indent=2)
|
||||||
return data
|
return data
|
||||||
|
|
||||||
def read(self, nbrMsg, outbox, isJSON):
|
|
||||||
jsonMsg = self.sendDocument(nbrMsg, outbox)
|
|
||||||
if isJSON:
|
|
||||||
jsonFormat = self.jsonMessages(jsonMsg, nbrMsg, outbox)
|
|
||||||
print(jsonFormat)
|
|
||||||
else:
|
|
||||||
self.readMessages(jsonMsg, nbrMsg, outbox)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -181,33 +220,7 @@ class ReadFromCesium:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class SendToCesium:
|
class SendToCesium(CesiumPlus):
|
||||||
def __init__(self, dunikey, pod, recipient, outbox):
|
|
||||||
# Get my pubkey from my private key
|
|
||||||
try:
|
|
||||||
self.dunikey = dunikey
|
|
||||||
if not dunikey:
|
|
||||||
raise ValueError("Dunikey is empty")
|
|
||||||
except:
|
|
||||||
sys.stderr.write("Please fill the path to your private key (PubSec)\n")
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
self.issuer = get_privkey(dunikey, "pubsec").pubkey
|
|
||||||
self.pod = pod
|
|
||||||
self.recipient = recipient
|
|
||||||
self.outbox = outbox
|
|
||||||
|
|
||||||
# Generate pseudo-random nonce
|
|
||||||
nonce=[]
|
|
||||||
for _ in range(32):
|
|
||||||
nonce.append(random.choice(string.ascii_letters + string.digits))
|
|
||||||
self.nonce = base64.b64decode(''.join(nonce))
|
|
||||||
|
|
||||||
if not re.match(PUBKEY_REGEX, recipient) or len(recipient) > 45:
|
|
||||||
sys.stderr.write("La clé publique n'est pas au bon format.\n")
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
|
|
||||||
def encryptMsg(self, msg):
|
def encryptMsg(self, msg):
|
||||||
return fmt["64"](box_encrypt(msg.encode(), get_privkey(self.dunikey, "pubsec"), self.recipient, self.nonce)).decode()
|
return fmt["64"](box_encrypt(msg.encode(), get_privkey(self.dunikey, "pubsec"), self.recipient, self.nonce)).decode()
|
||||||
|
|
||||||
|
@ -219,7 +232,7 @@ class SendToCesium:
|
||||||
|
|
||||||
# Generate custom JSON
|
# Generate custom JSON
|
||||||
data = {}
|
data = {}
|
||||||
data['issuer'] = self.issuer
|
data['issuer'] = self.pubkey
|
||||||
data['recipient'] = self.recipient
|
data['recipient'] = self.recipient
|
||||||
data['title'] = title
|
data['title'] = title
|
||||||
data['content'] = msg
|
data['content'] = msg
|
||||||
|
@ -228,20 +241,11 @@ class SendToCesium:
|
||||||
data['version'] = 2
|
data['version'] = 2
|
||||||
document = json.dumps(data)
|
document = json.dumps(data)
|
||||||
|
|
||||||
# Generate hash of document
|
return self.signDoc(document)
|
||||||
hashDoc = sha256(document.encode()).hexdigest().upper()
|
|
||||||
|
|
||||||
# Generate signature of document
|
|
||||||
signature = fmt["64"](sign(hashDoc.encode(), get_privkey(self.dunikey, "pubsec"))[:-len(hashDoc.encode())]).decode()
|
|
||||||
|
|
||||||
# Build final document
|
|
||||||
finalDoc = '{' + '"hash":"{0}","signature":"{1}",'.format(hashDoc, signature) + document[1:]
|
|
||||||
|
|
||||||
return finalDoc
|
|
||||||
|
|
||||||
|
|
||||||
def sendDocument(self, document):
|
def sendDocument(self, document, outbox):
|
||||||
boxType = "outbox" if self.outbox else "inbox"
|
boxType = "outbox" if outbox else "inbox"
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
'Content-type': 'application/json',
|
'Content-type': 'application/json',
|
||||||
|
@ -262,9 +266,6 @@ class SendToCesium:
|
||||||
sys.stderr.write("Erreur inconnue:" + '\n')
|
sys.stderr.write("Erreur inconnue:" + '\n')
|
||||||
print(str(pp_json(result.text)) + '\n')
|
print(str(pp_json(result.text)) + '\n')
|
||||||
|
|
||||||
def send(self, title, msg):
|
|
||||||
finalDoc = self.configDoc(self.encryptMsg(title), self.encryptMsg(msg)) # Configure JSON document to send
|
|
||||||
self.sendDocument(finalDoc) # Send final signed document
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -274,27 +275,12 @@ class SendToCesium:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class DeleteFromCesium:
|
class DeleteFromCesium(CesiumPlus):
|
||||||
def __init__(self, dunikey, pod, outbox):
|
def configDoc(self, idMsg, outbox):
|
||||||
# Get my pubkey from my private key
|
|
||||||
try:
|
|
||||||
self.dunikey = dunikey
|
|
||||||
if not dunikey:
|
|
||||||
raise ValueError("Dunikey is empty")
|
|
||||||
except:
|
|
||||||
sys.stderr.write("Please fill the path to your private key (PubSec)\n")
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
self.issuer = get_privkey(dunikey, "pubsec").pubkey
|
|
||||||
self.pod = pod
|
|
||||||
self.outbox = outbox
|
|
||||||
|
|
||||||
|
|
||||||
def configDoc(self, idMsg):
|
|
||||||
# Get current timestamp
|
# Get current timestamp
|
||||||
timeSent = int(time.time())
|
timeSent = int(time.time())
|
||||||
|
|
||||||
boxType = "outbox" if self.outbox else "inbox"
|
boxType = "outbox" if outbox else "inbox"
|
||||||
|
|
||||||
# Generate document to customize
|
# Generate document to customize
|
||||||
data = {}
|
data = {}
|
||||||
|
@ -302,25 +288,11 @@ class DeleteFromCesium:
|
||||||
data['index'] = "message"
|
data['index'] = "message"
|
||||||
data['type'] = boxType
|
data['type'] = boxType
|
||||||
data['id'] = idMsg
|
data['id'] = idMsg
|
||||||
data['issuer'] = self.issuer
|
data['issuer'] = self.pubkey
|
||||||
data['time'] = timeSent
|
data['time'] = timeSent
|
||||||
document = json.dumps(data)
|
document = json.dumps(data)
|
||||||
|
|
||||||
# Generate hash of document
|
return self.signDoc(document)
|
||||||
hashDoc = sha256(document.encode()).hexdigest().upper()
|
|
||||||
|
|
||||||
# Generate signature of document
|
|
||||||
signature = fmt["64"](sign(hashDoc.encode(), get_privkey(self.dunikey, "pubsec"))[:-len(hashDoc.encode())]).decode()
|
|
||||||
|
|
||||||
# Build final document
|
|
||||||
data = {}
|
|
||||||
data['hash'] = hashDoc
|
|
||||||
data['signature'] = signature
|
|
||||||
signJSON = json.dumps(data)
|
|
||||||
finalJSON = {**json.loads(signJSON), **json.loads(document)}
|
|
||||||
finalDoc = json.dumps(finalJSON)
|
|
||||||
|
|
||||||
return finalDoc
|
|
||||||
|
|
||||||
def sendDocument(self, document, idMsg):
|
def sendDocument(self, document, idMsg):
|
||||||
headers = {
|
headers = {
|
||||||
|
@ -344,11 +316,6 @@ class DeleteFromCesium:
|
||||||
else:
|
else:
|
||||||
sys.stderr.write("Erreur inconnue.")
|
sys.stderr.write("Erreur inconnue.")
|
||||||
|
|
||||||
def delete(self, idsMsgList):
|
|
||||||
for idMsg in idsMsgList:
|
|
||||||
finalDoc = self.configDoc(idMsg)
|
|
||||||
self.sendDocument(finalDoc, idMsg)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue