Skip to content

Commit

Permalink
[MIG] edi_storage_oca: Migration to 16.0
Browse files Browse the repository at this point in the history
  • Loading branch information
duongtq committed Dec 1, 2023
1 parent 9d52254 commit b0e99b8
Show file tree
Hide file tree
Showing 20 changed files with 132 additions and 241 deletions.
29 changes: 20 additions & 9 deletions edi_storage_oca/README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ EDI Storage backend support
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:f2718fe12ff53362a2da3e253d22e0641ebcd6a01195db14f8d9c8c71878080d
!! source digest: sha256:3806d6eaf0c3ce46d7d24b5c5e002f0c49a42390385f23e4480a33dd94e85451
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
Expand All @@ -16,14 +16,14 @@ EDI Storage backend support
.. |badge2| image:: https://img.shields.io/badge/licence-LGPL--3-blue.png
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fedi-lightgray.png?logo=github
:target: https://github.com/OCA/edi/tree/15.0/edi_storage_oca
:alt: OCA/edi
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fedi--framework-lightgray.png?logo=github
:target: https://github.com/OCA/edi-framework/tree/16.0/edi_storage_oca
:alt: OCA/edi-framework
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/edi-15-0/edi-15-0-edi_storage_oca
:target: https://translation.odoo-community.org/projects/edi-framework-16-0/edi-framework-16-0-edi_storage_oca
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/edi&target_branch=15.0
:target: https://runboat.odoo-community.org/builds?repo=OCA/edi-framework&target_branch=16.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|
Expand Down Expand Up @@ -62,13 +62,18 @@ Usage

Go to "EDI -> EDI backend" then configure your backend to use a storage backend.

Known issues / Roadmap
======================

* clean deprecated methods in the storage

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/edi/issues>`_.
Bugs are tracked on `GitHub Issues <https://github.com/OCA/edi-framework/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/edi/issues/new?body=module:%20edi_storage_oca%0Aversion:%2015.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.
`feedback <https://github.com/OCA/edi-framework/issues/new?body=module:%20edi_storage_oca%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Expand All @@ -86,6 +91,12 @@ Contributors
* Simone Orsi <[email protected]>
* Foram Shah <[email protected]>
* Lois Rilo <[email protected]>
* Duong (Tran Quoc) <[email protected]>

Other credits
~~~~~~~~~~~~~

The migration of this module from 15.0 to 16.0 was financially supported by Camptocamp.

Maintainers
~~~~~~~~~~~
Expand All @@ -100,6 +111,6 @@ OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

This module is part of the `OCA/edi <https://github.com/OCA/edi/tree/15.0/edi_storage_oca>`_ project on GitHub.
This module is part of the `OCA/edi-framework <https://github.com/OCA/edi-framework/tree/16.0/edi_storage_oca>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
6 changes: 3 additions & 3 deletions edi_storage_oca/__manifest__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@
"summary": """
Base module to allow exchanging files via storage backend (eg: SFTP).
""",
"version": "15.0.1.2.0",
"version": "16.0.1.0.0",
"development_status": "Beta",
"license": "LGPL-3",
"website": "https://github.com/OCA/edi",
"website": "https://github.com/OCA/edi-framework",
"author": "ACSONE,Odoo Community Association (OCA)",
"depends": ["edi_oca", "storage_backend", "component"],
"depends": ["edi_oca", "fs_storage", "component"],
"data": [
"data/cron.xml",
"data/job_channel_data.xml",
Expand Down
25 changes: 6 additions & 19 deletions edi_storage_oca/components/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,16 +14,16 @@ class EDIStorageComponentMixin(AbstractComponent):

_name = "edi.storage.component.mixin"
_inherit = "edi.component.mixin"
# Components having `_storage_backend_type` will have precedence.
# Components having `_storage_type` will have precedence.
# If the value is not set, generic components will be used.
_storage_backend_type = None
_storage_type = None

@classmethod
def _component_match(cls, work, usage=None, model_name=None, **kw):
res = super()._component_match(work, usage=usage, model_name=model_name, **kw)
storage_type = kw.get("storage_backend_type")
if storage_type and cls._storage_backend_type:
return cls._storage_backend_type == storage_type
storage_type = kw.get("storage_type")
if storage_type and cls._storage_type:
return cls._storage_type == storage_type
return res

@property
Expand All @@ -43,20 +43,6 @@ def _dir_by_state(self, direction, state):
(self.backend[direction + "_dir_" + state] or "").strip().rstrip("/")
)

def _remote_file_path(self, direction, state, filename):
"""Return remote file path by direction and state for give filename.
:param direction: string stating direction of the exchange
:param state: string stating state of the exchange
:param filename: string for file name
:return: PurePath object
"""
_logger.warning(
"Call of deprecated function `_remote_file_path`. "
"Please use `_get_remote_file_path` instead.",
)
return self._dir_by_state(direction, state) / filename.strip("/ ")

def _get_remote_file_path(self, state, filename=None):
"""Retrieve remote path for current exchange record."""
filename = filename or self.exchange_record.exchange_filename
Expand All @@ -79,6 +65,7 @@ def _get_remote_file(self, state, filename=None, binary=False):
# TODO: support match via pattern (eg: filename-prefix-*)
# otherwise is impossible to retrieve input files and acks
# (the date will never match)
# TODO: clean this up, .get is deprecated in fs_storage
return self.storage.get(path.as_posix(), binary=binary)
except FileNotFoundError:
_logger.info(
Expand Down
21 changes: 0 additions & 21 deletions edi_storage_oca/components/check.py
Original file line number Diff line number Diff line change
Expand Up @@ -69,24 +69,3 @@ def _exchange_output_check(self):
self.exchange_record._notify_error("process_ko")
return False
return True

# FIXME: this is not used ATM -> should be refactored
# into an incoming exchange.
# The backend will look for records needing an ack
# and generate and ack record.
def _exchange_output_handle_ack(self):
ack_type = self.exchange_record.type_id.ack_type_id
filename = ack_type._make_exchange_filename(self.exchange_record)
ack_file = self._get_remote_file("done", filename=filename)
if ack_file:
self.backend.create_record(
ack_type.code,
{
"parent_id": self.exchange_record.id,
"exchange_file": ack_file,
"edi_exchange_state": "input_received",
},
)
self.exchange_record._notify_ack_received()
else:
self.exchange_record._notify_ack_missing()
21 changes: 13 additions & 8 deletions edi_storage_oca/components/listener.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).

import functools
import os
from pathlib import PurePath

from odoo.addons.component.core import Component
Expand All @@ -14,19 +15,23 @@ class EdiStorageListener(Component):
def _move_file(self, storage, from_dir_str, to_dir_str, filename):
from_dir = PurePath(from_dir_str)
to_dir = PurePath(to_dir_str)

Check warning on line 17 in edi_storage_oca/components/listener.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/listener.py#L16-L17

Added lines #L16 - L17 were not covered by tests
if filename not in storage.list_files(from_dir.as_posix()):
# The file might have been moved after a previous error.
# - storage.list_files now includes path in fs_storage, breaking change
# - we remove path
# TODO: clean this up, .list_files is deprecated in fs_storage
files = storage.list_files(from_dir.as_posix())

Check warning on line 21 in edi_storage_oca/components/listener.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/listener.py#L21

Added line #L21 was not covered by tests
files = [os.path.basename(f) for f in files]
if filename not in files:
return False

Check warning on line 24 in edi_storage_oca/components/listener.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/listener.py#L24

Added line #L24 was not covered by tests
self._add_after_commit_hook(
storage._move_files, [(from_dir / filename).as_posix()], to_dir.as_posix()
# TODO: clean this up, .move_files is deprecated in fs_storage
self._add_post_commit_hook(

Check warning on line 26 in edi_storage_oca/components/listener.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/listener.py#L26

Added line #L26 was not covered by tests
storage.move_files, [(from_dir / filename).as_posix()], to_dir.as_posix()
)
return True

Check warning on line 29 in edi_storage_oca/components/listener.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/listener.py#L29

Added line #L29 was not covered by tests

def _add_after_commit_hook(self, move_func, sftp_filepath, sftp_destination_path):
def _add_post_commit_hook(self, move_func, sftp_filepath, sftp_destination_path):
"""Add hook after commit to move the file when transaction is over."""
self.env.cr.after(
"commit",
functools.partial(move_func, sftp_filepath, sftp_destination_path),
self.env.cr.postcommit.add(

Check warning on line 33 in edi_storage_oca/components/listener.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/listener.py#L33

Added line #L33 was not covered by tests
functools.partial(move_func, sftp_filepath, sftp_destination_path)
)

def on_edi_exchange_done(self, record):
Expand Down
1 change: 1 addition & 0 deletions edi_storage_oca/components/receive.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,6 @@ class EDIStorageReceiveComponent(Component):

def receive(self):
path = self._get_remote_file_path("pending")

Check warning on line 17 in edi_storage_oca/components/receive.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/receive.py#L17

Added line #L17 was not covered by tests
# TODO: clean this up, .get is deprecated in fs_storage
filedata = self.storage.get(path.as_posix())
return filedata

Check warning on line 20 in edi_storage_oca/components/receive.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/receive.py#L19-L20

Added lines #L19 - L20 were not covered by tests
1 change: 1 addition & 0 deletions edi_storage_oca/components/send.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ def send(self):
return True

Check warning on line 25 in edi_storage_oca/components/send.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/components/send.py#L25

Added line #L25 was not covered by tests
filedata = self.exchange_record.exchange_file
path = self._get_remote_file_path("pending")
# TODO: clean this up, .add is deprecated in fs_storage
self.storage.add(path.as_posix(), filedata, binary=False)
# TODO: delegate this to generic storage backend
# except paramiko.ssh_exception.AuthenticationException:
Expand Down
2 changes: 1 addition & 1 deletion edi_storage_oca/demo/edi_backend_demo.xml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
<record id="demo_edi_backend_storage" model="edi.backend">
<field name="name">Storage Demo EDI backend</field>
<field name="backend_type_id" ref="edi_oca.demo_edi_backend_type" />
<field name="storage_id" ref="storage_backend.default_storage_backend" />
<field name="storage_id" ref="fs_storage.default_fs_storage" />
<field name="input_dir_pending">demo_in/pending</field>
<field name="input_dir_done">demo_in/done</field>
<field name="input_dir_error">demo_in/error</field>
Expand Down
106 changes: 0 additions & 106 deletions edi_storage_oca/i18n/edi_storage_oca.pot

This file was deleted.

16 changes: 8 additions & 8 deletions edi_storage_oca/models/edi_backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ class EDIBackend(models.Model):
_inherit = "edi.backend"

storage_id = fields.Many2one(
string="Storage backend",
comodel_name="storage.backend",
string="FS Storage",
comodel_name="fs.storage",
help="Storage for in-out files",
ondelete="restrict",
)
Expand Down Expand Up @@ -67,21 +67,19 @@ def _get_component_usage_candidates(self, exchange_record, key):
return ["storage.{}".format(key)] + candidates

def _component_match_attrs(self, exchange_record, key):
# Override to inject storage_backend_type
# Override to inject storage_type
res = super()._component_match_attrs(exchange_record, key)
if not self.storage_id or key not in self._storage_actions:
return res
res["storage_backend_type"] = self.storage_id.backend_type
res["storage_type"] = self.storage_id.protocol
return res

def _component_sort_key(self, component_class):
res = super()._component_sort_key(component_class)
# Override to give precedence by storage_backend_type when needed.
# Override to give precedence by storage_type when needed.
if not self.storage_id:
return res
return (
1 if getattr(component_class, "_storage_backend_type", False) else 0,
) + res
return (1 if getattr(component_class, "_storage_type", False) else 0,) + res

def _storage_cron_check_pending_input(self, **kw):
for backend in self:
Expand Down Expand Up @@ -150,6 +148,7 @@ def _storage_get_input_filenames(self, exchange_type):
).as_posix()
if not exchange_type.exchange_filename_pattern:
# If there is not pattern, return everything
# TODO: clean this up, .list_files is deprecated in fs_storage
filenames = [
x
for x in self.storage_id.list_files(full_input_dir_pending)
Expand All @@ -161,6 +160,7 @@ def _storage_get_input_filenames(self, exchange_type):
if exchange_type.exchange_file_ext:
bits.append(r"\." + exchange_type.exchange_file_ext)
pattern = "".join(bits)

Check warning on line 162 in edi_storage_oca/models/edi_backend.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/models/edi_backend.py#L161-L162

Added lines #L161 - L162 were not covered by tests
# TODO: clean this up, .find_files is deprecated in fs_storage
full_paths = self.storage_id.find_files(pattern, full_input_dir_pending)
pending_path_len = len(full_input_dir_pending)

Check warning on line 165 in edi_storage_oca/models/edi_backend.py

View check run for this annotation

Codecov / codecov/patch

edi_storage_oca/models/edi_backend.py#L164-L165

Added lines #L164 - L165 were not covered by tests
return [p[pending_path_len:].strip("/") for p in full_paths]
Expand Down
1 change: 1 addition & 0 deletions edi_storage_oca/readme/CONTRIBUTORS.rst
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
* Simone Orsi <[email protected]>
* Foram Shah <[email protected]>
* Lois Rilo <[email protected]>
* Duong (Tran Quoc) <[email protected]>
1 change: 1 addition & 0 deletions edi_storage_oca/readme/CREDITS.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
The migration of this module from 15.0 to 16.0 was financially supported by Camptocamp.
1 change: 1 addition & 0 deletions edi_storage_oca/readme/ROADMAP.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
* clean deprecated methods in the storage
Loading

0 comments on commit b0e99b8

Please sign in to comment.