converted everything to use project server and log
This commit is contained in:
parent
5292c409ca
commit
b752941779
1
.gitignore
vendored
1
.gitignore
vendored
@ -1 +1,2 @@
|
|||||||
approved_projects/*
|
approved_projects/*
|
||||||
|
__pycache__/*
|
||||||
|
|||||||
@ -1,8 +1,14 @@
|
|||||||
import pika
|
import pika
|
||||||
|
|
||||||
|
import pickle
|
||||||
|
|
||||||
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost', 5672, '/', pika.PlainCredentials("user", "password")))
|
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost', 5672, '/', pika.PlainCredentials("user", "password")))
|
||||||
channel = connection.channel()
|
channel = connection.channel()
|
||||||
|
|
||||||
def log(data):
|
def log(data):
|
||||||
channel.basic_publish(exchange='', routing_key='log', body=data)
|
channel.basic_publish(exchange='', routing_key='log', body=data)
|
||||||
|
|
||||||
|
def save_project(project):
|
||||||
|
channel.basic_publish(exchange='', routing_key='save_project',
|
||||||
|
body=pickle.dumps(project))
|
||||||
|
|
||||||
|
|||||||
@ -1,6 +1,11 @@
|
|||||||
import pika
|
import pika
|
||||||
|
|
||||||
from functions import log
|
import pickle
|
||||||
|
|
||||||
|
from functions import log, save_project
|
||||||
|
from classes import *
|
||||||
|
|
||||||
|
remaining_funds = 1000000
|
||||||
|
|
||||||
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost', 5672, '/', pika.PlainCredentials("user", "password")))
|
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost', 5672, '/', pika.PlainCredentials("user", "password")))
|
||||||
|
|
||||||
@ -9,23 +14,23 @@ channel = connection.channel()
|
|||||||
channel.queue_declare(queue='research_proposals')
|
channel.queue_declare(queue='research_proposals')
|
||||||
|
|
||||||
def process_proposal(ch, method, properties, body):
|
def process_proposal(ch, method, properties, body):
|
||||||
proposal = body.decode()
|
project = pickle.loads(body)
|
||||||
acronym, title, description, amount = proposal.split(',')
|
if 200000 <= project.amount <= 500000 and project.amount <= remaining_funds:
|
||||||
|
|
||||||
if 200000 <= int(amount) <= 500000:
|
|
||||||
channel.basic_publish(exchange='',
|
channel.basic_publish(exchange='',
|
||||||
routing_key=properties.reply_to,
|
routing_key=properties.reply_to,
|
||||||
properties=pika.BasicProperties(correlation_id=properties.correlation_id),
|
properties=pika.BasicProperties(correlation_id=properties.correlation_id),
|
||||||
body="approved")
|
body="approved")
|
||||||
project_info=f"{acronym},{title},{description},{amount}"
|
project.status = 1
|
||||||
channel.basic_publish(exchange='', routing_key='approved_projects', body=project_info)
|
save_project(project)
|
||||||
log(f"{acronym} approved")
|
log(f"{project.acronym} approved")
|
||||||
else:
|
else:
|
||||||
channel.basic_publish(exchange='',
|
channel.basic_publish(exchange='',
|
||||||
routing_key=properties.reply_to,
|
routing_key=properties.reply_to,
|
||||||
properties=pika.BasicProperties(correlation_id=properties.correlation_id),
|
properties=pika.BasicProperties(correlation_id=properties.correlation_id),
|
||||||
body="rejected")
|
body="rejected")
|
||||||
log(f"{acronym} rejected")
|
project.status = 2
|
||||||
|
save_project(project)
|
||||||
|
log(f"{project.acronym} rejected")
|
||||||
|
|
||||||
channel.basic_consume(queue='research_proposals', on_message_callback=process_proposal, auto_ack=True)
|
channel.basic_consume(queue='research_proposals', on_message_callback=process_proposal, auto_ack=True)
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,8 @@ import pika
|
|||||||
import pickle
|
import pickle
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from classes import Project
|
from classes import Project, Transaction
|
||||||
|
from functions import log
|
||||||
|
|
||||||
if not os.path.exists("approved_projects"):
|
if not os.path.exists("approved_projects"):
|
||||||
os.makedirs("approved_projects")
|
os.makedirs("approved_projects")
|
||||||
@ -27,16 +28,17 @@ def get_project(ch, method, properties, body):
|
|||||||
|
|
||||||
|
|
||||||
def save_project(ch, method, properties, body):
|
def save_project(ch, method, properties, body):
|
||||||
project_data = body.decode()
|
project = pickle.loads(body)
|
||||||
acronym, title, description, amount = project_data.split(',')
|
filename = os.path.join("approved_projects", f"{project.acronym}.txt")
|
||||||
|
|
||||||
project = Project(acronym, title, description, int(amount))
|
|
||||||
filename = os.path.join("approved_projects", f"{acronym}.txt")
|
|
||||||
with open(filename, "wb+") as file:
|
with open(filename, "wb+") as file:
|
||||||
pickle.dump(project, file)
|
pickle.dump(project, file)
|
||||||
|
|
||||||
|
|
||||||
channel.basic_consume(queue='get_project', on_message_callback=get_project, auto_ack=False)
|
channel.basic_consume(queue='get_project', on_message_callback=get_project, auto_ack=True)
|
||||||
channel.basic_consume(queue='save_project', on_message_callback=save_project, auto_ack=True)
|
channel.basic_consume(queue='save_project', on_message_callback=save_project, auto_ack=True)
|
||||||
|
|
||||||
|
try:
|
||||||
channel.start_consuming()
|
channel.start_consuming()
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
channel.stop_consuming()
|
||||||
|
connection.close()
|
||||||
|
|||||||
@ -1,8 +1,10 @@
|
|||||||
import pika
|
import pika
|
||||||
|
|
||||||
import uuid
|
import uuid
|
||||||
|
import pickle
|
||||||
|
|
||||||
from functions import log
|
from functions import *
|
||||||
|
from classes import *
|
||||||
|
|
||||||
class ResearchProposal(object):
|
class ResearchProposal(object):
|
||||||
|
|
||||||
@ -15,25 +17,23 @@ class ResearchProposal(object):
|
|||||||
self.response = None
|
self.response = None
|
||||||
self.corr_id = None
|
self.corr_id = None
|
||||||
|
|
||||||
|
|
||||||
def on_response(self, ch, method, properties, body):
|
def on_response(self, ch, method, properties, body):
|
||||||
if self.corr_id == properties.correlation_id:
|
if self.corr_id == properties.correlation_id:
|
||||||
self.response = body
|
self.response = body
|
||||||
|
|
||||||
def call(self, n):
|
def call(self, proposal):
|
||||||
|
project = Project(proposal["acronym"], proposal["title"],
|
||||||
|
proposal["description"], int(proposal["amount"]))
|
||||||
|
save_project(project)
|
||||||
self.response = None
|
self.response = None
|
||||||
self.corr_id = str(uuid.uuid4())
|
self.corr_id = str(uuid.uuid4())
|
||||||
self.channel.basic_publish(exchange='', routing_key="research_proposals",
|
self.channel.basic_publish(exchange='', routing_key="research_proposals",
|
||||||
properties=pika.BasicProperties(reply_to=self.callback_queue,
|
properties=pika.BasicProperties(reply_to=self.callback_queue,
|
||||||
correlation_id=self.corr_id, ),
|
correlation_id=self.corr_id, ),
|
||||||
body=f"{n['acronym']},{n['title']},{n['description']},{n['amount']}")
|
body=pickle.dumps(project))
|
||||||
self.connection.process_data_events(time_limit=None)
|
self.connection.process_data_events(time_limit=None)
|
||||||
return str(self.response)
|
return str(self.response)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
proposals = [
|
proposals = [
|
||||||
{"acronym": "PROJ1", "title": "Project 1", "description": "Description 1", "amount": "300000"},
|
{"acronym": "PROJ1", "title": "Project 1", "description": "Description 1", "amount": "300000"},
|
||||||
{"acronym": "PROJ2", "title": "Project 2", "description": "Description 2", "amount": "400000"},
|
{"acronym": "PROJ2", "title": "Project 2", "description": "Description 2", "amount": "400000"},
|
||||||
@ -43,7 +43,6 @@ proposals = [
|
|||||||
{"acronym": "PROJ6", "title": "Project 6", "description": "Description 6", "amount": "420000"}
|
{"acronym": "PROJ6", "title": "Project 6", "description": "Description 6", "amount": "420000"}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
for proposal in proposals:
|
for proposal in proposals:
|
||||||
proposal_client = ResearchProposal()
|
proposal_client = ResearchProposal()
|
||||||
log(f"{proposal['acronym']} sends proposal")
|
log(f"{proposal['acronym']} sends proposal")
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user