-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
GO-128 Download messages from FS #483
Changes from 12 commits
bb0a0a0
0ac9aa8
ce6ab5b
95e9b4e
154ee47
6e6ac84
823fe35
0dbe7f0
41e10c9
47899d5
fdbe251
a32b402
8ac7511
2f935b6
351dce0
fd14363
be51628
e19f6e4
1b81b73
7d2fd3e
0747cc4
6840c4f
50ca8c5
6dbbe2c
58bfcc2
63ce7b3
a5167d9
1c38460
266ffa0
84f1650
dcfd011
5d9e89d
5d135b3
7307fae
9de9135
16dc11c
6a97f21
8474ba5
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
module Fs::MessageHelper | ||
def self.build_html_visualization(message) | ||
return [ActionController::Base.new.render_to_string('fs/messages/_submission', layout: false, locals: { message: message }), build_html_visualization_from_form(message)].compact.join('<hr>') if message.outbox? | ||
|
||
# TODO: Vieme aj lepsie identifikovat? Nejake dalsie typy v tejto kategorii neexistuju? | ||
template = if message.title.in?(['Informácia o podaní', 'Informácia o odmietnutí podania']) | ||
'fs/messages/_delivery_report' | ||
else | ||
'fs/messages/_generic_message' | ||
end | ||
|
||
ActionController::Base.new.render_to_string(template, layout: false, locals: { message: message }) | ||
end | ||
|
||
def self.build_html_visualization_from_form(message) | ||
return unless message.form&.xslt_txt | ||
return unless message.form_object&.unsigned_content | ||
|
||
template = Nokogiri::XSLT(message.form.xslt_txt) | ||
ActionController::Base.helpers.simple_format(template.transform(message.form_object.xml_unsigned_content).to_s) | ||
end | ||
end |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
class Fs::DownloadReceivedMessageJob < ApplicationJob | ||
def perform(fs_message_id, box:, fs_client: FsEnvironment.fs_client) | ||
return if Message.where("metadata ->> 'fs_message_id' = ?", fs_message_id).any? | ||
luciajanikova marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
fs_api = fs_client.api(api_connection: box.api_connection, box: box) | ||
|
||
raw_message = fs_api.fetch_received_message(fs_message_id) | ||
|
||
Fs::Message.create_inbox_message_with_thread!(raw_message, box: box) | ||
end | ||
end |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
class Fs::DownloadSentMessageJob < ApplicationJob | ||
def perform(fs_message_id, box:, fs_client: FsEnvironment.fs_client) | ||
fs_api = fs_client.api(api_connection: box.api_connection, box: box) | ||
|
||
raw_message = fs_api.fetch_sent_message(fs_message_id) | ||
|
||
Fs::Message.create_outbox_message_with_thread!(raw_message, box: box) | ||
end | ||
end |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
class Fs::DownloadSentMessageRelatedMessagesJob < ApplicationJob | ||
def perform(outbox_message, fs_client: FsEnvironment.fs_client) | ||
fs_api = fs_client.api(api_connection: outbox_message.box.api_connection, box: outbox_message.box) | ||
|
||
received_messages = fs_api.fetch_received_messages(sent_message_id: outbox_message.metadata['fs_message_id']) | ||
|
||
received_messages['messages'].each do |received_message| | ||
::Fs::DownloadReceivedMessageJob.perform_later(received_message['message_id'], box: outbox_message.box) | ||
end | ||
end | ||
end |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,133 @@ | ||
class Fs::Message | ||
luciajanikova marked this conversation as resolved.
Show resolved
Hide resolved
|
||
FS_SUBJECT_NAME = 'Finančná správa' | ||
|
||
def self.create_inbox_message_with_thread!(raw_message, box:) | ||
message = nil | ||
associated_outbox_message = box.messages.where("metadata ->> 'fs_message_id' = ?", raw_message['sent_message_id']).take | ||
|
||
MessageThread.with_advisory_lock!(associated_outbox_message.metadata['correlation_id'], transaction: true, timeout_seconds: 10) do | ||
message = create_inbox_message(raw_message) | ||
|
||
message.thread = associated_outbox_message.thread | ||
|
||
message.save! | ||
end | ||
|
||
create_message_objects(message, raw_message) | ||
update_html_visualization(message) | ||
|
||
EventBus.publish(:message_created, message) | ||
end | ||
|
||
def self.create_outbox_message_with_thread!(raw_message, box:) | ||
message = nil | ||
associated_message_draft = box.messages.where(type: 'Fs::MessageDraft').where("metadata ->> 'fs_message_id' = ?", raw_message['message_id']).take | ||
|
||
merge_identifier = (associated_message_draft.metadata['correlation_id'] if associated_message_draft) || SecureRandom.uuid | ||
|
||
MessageThread.with_advisory_lock!(merge_identifier, transaction: true, timeout_seconds: 10) do | ||
message = create_outbox_message(raw_message) | ||
|
||
message.thread = box.message_threads.find_or_create_by_merge_uuid!( | ||
box: box, | ||
merge_uuid: merge_identifier, | ||
title: message.title, | ||
delivered_at: message.delivered_at | ||
) | ||
|
||
associated_message_draft.destroy if associated_message_draft | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nebude tu rovnaky problem so stracajucimi sa tagmi? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Bude, myslim na to, ale logiku toho by som vyladila v tom otvorenom PR najprv a potom to lahko preklopim aj sem. Nech to neriesime teraz na dvoch miestach. |
||
|
||
message.save! | ||
end | ||
|
||
create_message_objects(message, raw_message) | ||
update_html_visualization(message) | ||
|
||
EventBus.publish(:message_created, message) | ||
end | ||
|
||
private | ||
|
||
def self.create_inbox_message(raw_message) | ||
Message.create( | ||
uuid: SecureRandom.uuid, | ||
title: raw_message['message_type_name'], | ||
sender_name: FS_SUBJECT_NAME, | ||
recipient_name: raw_message['subject'], | ||
delivered_at: Time.parse(raw_message['created_at']).getlocal, | ||
replyable: false, | ||
collapsed: collapsed?, | ||
outbox: false, | ||
metadata: { | ||
"fs_message_id": raw_message['message_id'], | ||
"fs_sent_message_id": raw_message['sent_message_id'], | ||
"fs_status": raw_message['status'], | ||
"fs_submitting_subject": raw_message['submitting_subject'], | ||
"fs_submission_status": raw_message['submission_status'], | ||
"fs_submission_created_at": Time.parse(raw_message['submission_created_at']).getlocal, | ||
"dic": raw_message['dic'] | ||
}, | ||
) | ||
end | ||
|
||
def self.create_outbox_message(raw_message, associated_message_draft: nil) | ||
Message.create( | ||
uuid: (associated_message_draft.uuid if associated_message_draft) || SecureRandom.uuid, | ||
title: raw_message['submission_type_name'], | ||
sender_name: raw_message['subject'], | ||
recipient_name: FS_SUBJECT_NAME, | ||
delivered_at: Time.parse(raw_message['created_at']).getlocal, | ||
replyable: false, | ||
collapsed: collapsed?, | ||
outbox: true, | ||
metadata: { | ||
"fs_form_id": (associated_message_draft.metadata['fs_form_id'] if associated_message_draft) || Fs::Form.where("identifier LIKE '#{raw_message['submission_type_id']}_%'")&.take&.id, | ||
"fs_message_id": raw_message['message_id'], | ||
"fs_status": raw_message['status'], | ||
"submitting_subject": raw_message['submitting_subject'], | ||
"dic": raw_message['dic'] | ||
}, | ||
) | ||
end | ||
|
||
def self.create_message_objects(message, raw_message) | ||
raw_message.dig('message_container', 'objects').each do |raw_object| | ||
tags = raw_object["signed"] ? [message.thread.box.tenant.signed_externally_tag!] : [] | ||
|
||
message_object = message.objects.create!( | ||
# uuid: raw_object["id"], TODO uncomment when GO-130 is closed | ||
is_signed: raw_object["signed"], | ||
mimetype: raw_object["mime_type"], | ||
name: raw_object["name"], | ||
object_type: raw_object["class"], | ||
tags: tags | ||
) | ||
|
||
if raw_object["encoding"] == "Base64" | ||
message_object_content = Base64.decode64(raw_object["content"]) | ||
else | ||
message_object_content = raw_object["content"] | ||
end | ||
|
||
MessageObjectDatum.create!( | ||
blob: message_object_content, | ||
message_object: message_object | ||
) | ||
end | ||
end | ||
|
||
def self.update_html_visualization(message) | ||
message.update( | ||
html_visualization: Fs::MessageHelper.build_html_visualization(message) | ||
) | ||
|
||
message.form_object&.update( | ||
visualizable: message.html_visualization.present? | ||
) | ||
end | ||
|
||
def self.collapsed? | ||
# TODO urcit podmienky: odoslana sprava s potvrdenkou by mohla byt collapsed | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Kedze ta dorucenka je extremne dolezita pre nich, tak skor prave naopak. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Je to tu zle naformulovane, mala som na mysli, ze podanie by mohlo byt collapsed v pripade, ze uz prisla dorucenka. Toto su zatial rychle komentare v ramci draftu, doladim este. |
||
false | ||
end | ||
end |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Toto tu je otvorena vec. FS API v response vracia aj
message_type
, da sa identifikovat aj podla toho (ale tiez to je trochu len take hadanie, ked nemame nejaku dokumentaciu k tomu). Nevieme ako casto sa mozu zmenit bud tieto nazvy alebomessage_type
.Samotna dorucenka si myslim, ze problem nie je (tam by som sa spolahla aj na
message_type
), ale tieto negativne verzie su narocnejsie. Nevieme ani kolko typov existuje.