diff --git a/muk_fields_stream/LICENSE b/muk_fields_stream/LICENSE new file mode 100644 index 0000000..0a04128 --- /dev/null +++ b/muk_fields_stream/LICENSE @@ -0,0 +1,165 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. diff --git a/muk_fields_stream/README.rst b/muk_fields_stream/README.rst new file mode 100644 index 0000000..b209539 --- /dev/null +++ b/muk_fields_stream/README.rst @@ -0,0 +1,117 @@ +========================= +MuK Binary Stream Support +========================= + +This module adds a new http route which allows to download binary data as a stream. +This is especially useful for large files, because they don't fit in the ram as a +whole and can easily cause an error because ram limits are exceeded. This module +serves as a basis for a number of extensions that add fields to Odoo which support +this functionality. + +Installation +============ + +To install this module, you need to: + +Download the module and add it to your Odoo addons folder. Afterward, log on to +your Odoo server and go to the Apps menu. Trigger the debug mode and update the +list by clicking on the "Update Apps List" link. Now install the module by +clicking on the install button. + +Another way to install this module is via the package management for Python +(`PyPI `_). + +To install our modules using the package manager make sure +`odoo-autodiscover `_ is installed +correctly. Note that for Odoo version 11.0 and later this is not necessary anymore. +Then open a console and install the module by entering the following command: + +``pip install --extra-index-url https://nexus.mukit.at/repository/odoo/simple `` + +The module name consists of the Odoo version and the module name, where +underscores are replaced by a dash. + +**Module:** + +``odoo-addon-`` + +**Example:** + +``sudo -H pip3 install --extra-index-url https://nexus.mukit.at/repository/odoo/simple odoo13-addon-muk-utils`` + +Once the installation has been successfully completed, the app is already in the +correct folder. Log on to your Odoo server and go to the Apps menu. Trigger the +debug mode and update the list by clicking on the "Update Apps List" link. Now +install the module by clicking on the install button. + +The biggest advantage of this variant is that you can now also update the app +using the "pip" command. To do this, enter the following command in your console: + +``pip install --upgrade --extra-index-url https://nexus.mukit.at/repository/odoo/simple `` + +When the process is finished, restart your server and update the application in +Odoo. The steps are the same as for the installation only the button has changed +from "Install" to "Upgrade". + +You can also view available Apps directly in our `repository `_ +and find a more detailed installation guide on our `website `_. + +For modules licensed under a proprietary license, you will receive the access data after you purchased +the module. If the purchase were made at the Odoo store please contact our `support `_ +with a confirmation of the purchase to receive the corresponding access data. + +Upgrade +============ + +To upgrade this module, you need to: + +Download the module and add it to your Odoo addons folder. Restart the server +and log on to your Odoo server. Select the Apps menu and upgrade the module by +clicking on the upgrade button. + +If you installed the module using the "pip" command, you can also update the +module in the same way. Just type the following command into the console: + +``pip install --upgrade --extra-index-url https://nexus.mukit.at/repository/odoo/simple `` + +When the process is finished, restart your server and update the application in +Odoo, just like you would normally. + + +Configuration +============= + +No additional configuration is needed to use this module. + +Usage +===== + +This module has no direct visible effect on the system. It adds a new route +which can be used by modules which add fields with stream capability. + +Credit +====== + +Contributors +------------ + +* Mathias Markl + +Images +------ + +Some pictures are based on or inspired by the icon set of Font Awesome: + +* `Font Awesome `_ + +Author & Maintainer +------------------- + +This module is maintained by the `MuK IT GmbH `_. + +MuK IT is an Austrian company specialized in customizing and extending Odoo. +We develop custom solutions for your individual needs to help you focus on +your strength and expertise to grow your business. + +If you want to get in touch please contact us via `mail `_ +or visit our `website `_. diff --git a/muk_fields_stream/__init__.py b/muk_fields_stream/__init__.py new file mode 100644 index 0000000..19e9685 --- /dev/null +++ b/muk_fields_stream/__init__.py @@ -0,0 +1,23 @@ +################################################################################### +# +# Copyright (c) 2017-2019 MuK IT GmbH. +# +# This file is part of MuK Binary Stream Support +# (see https://mukit.at). +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# +################################################################################### + +from . import controllers, models diff --git a/muk_fields_stream/__manifest__.py b/muk_fields_stream/__manifest__.py new file mode 100644 index 0000000..a3dc319 --- /dev/null +++ b/muk_fields_stream/__manifest__.py @@ -0,0 +1,37 @@ +################################################################################### +# +# Copyright (c) 2017-2019 MuK IT GmbH. +# +# This file is part of MuK Binary Stream Support +# (see https://mukit.at). +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# +################################################################################### + +{ + "name": "MuK Binary Stream Support", + "summary": """Support for Binary Streams""", + "version": "13.0.1.0.0", + "category": "Extra Tools", + "license": "LGPL-3", + "website": "https://www.mukit.at", + "author": "MuK IT", + "contributors": ["Mathias Markl "], + "depends": ["muk_utils"], + "images": ["static/description/banner.png"], + "auto_install": False, + "application": False, + "installable": True, +} diff --git a/muk_fields_stream/controllers/__init__.py b/muk_fields_stream/controllers/__init__.py new file mode 100644 index 0000000..be2bbc0 --- /dev/null +++ b/muk_fields_stream/controllers/__init__.py @@ -0,0 +1,23 @@ +################################################################################### +# +# Copyright (c) 2017-2019 MuK IT GmbH. +# +# This file is part of MuK Binary Stream Support +# (see https://mukit.at). +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# +################################################################################### + +from . import main diff --git a/muk_fields_stream/controllers/main.py b/muk_fields_stream/controllers/main.py new file mode 100644 index 0000000..54a1502 --- /dev/null +++ b/muk_fields_stream/controllers/main.py @@ -0,0 +1,91 @@ +################################################################################### +# +# Copyright (c) 2017-2019 MuK IT GmbH. +# +# This file is part of MuK Binary Stream Support +# (see https://mukit.at). +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# +################################################################################### + +import logging + +from odoo import http +from odoo.http import request +from werkzeug import wrappers + +_logger = logging.getLogger(__name__) + + +class StreamController(http.Controller): + + # ---------------------------------------------------------- + # Routes + # ---------------------------------------------------------- + + @http.route( + [ + "/binary/content", + "/binary/content/", + "/binary/content//", + "/binary/content/", + "/binary/content//", + "/binary/content/-", + "/binary/content/-/", + "/binary/content/-//", + "/binary/content///", + "/binary/content////", + ], + type="http", + auth="public", + ) + def binary_content( + self, + xmlid=None, + model=None, + id=None, + field="content", + filename=None, + filename_field="content_fname", + unique=None, + mimetype=None, + download=None, + token=None, + access_token=None, + **kwargs + ): + status, headers, stream = request.env["ir.http"].binary_stream( + xmlid=xmlid, + model=model, + id=id, + field=field, + unique=unique, + filename=filename, + filename_field=filename_field, + download=download, + mimetype=mimetype, + access_token=access_token, + ) + if status != 200: + return request.env["ir.http"]._response_by_status(status, headers, False) + else: + headers.append(("Content-Length", stream.seek(0, 2))) + stream.seek(0, 0) + response = wrappers.Response( + stream, headers=headers, status=status, direct_passthrough=True + ) + if token: + response.set_cookie("fileToken", token) + return response diff --git a/muk_fields_stream/doc/changelog.rst b/muk_fields_stream/doc/changelog.rst new file mode 100644 index 0000000..9ee2b48 --- /dev/null +++ b/muk_fields_stream/doc/changelog.rst @@ -0,0 +1,4 @@ +`1.0.0` +------- + +- Init version diff --git a/muk_fields_stream/doc/index.rst b/muk_fields_stream/doc/index.rst new file mode 100644 index 0000000..b209539 --- /dev/null +++ b/muk_fields_stream/doc/index.rst @@ -0,0 +1,117 @@ +========================= +MuK Binary Stream Support +========================= + +This module adds a new http route which allows to download binary data as a stream. +This is especially useful for large files, because they don't fit in the ram as a +whole and can easily cause an error because ram limits are exceeded. This module +serves as a basis for a number of extensions that add fields to Odoo which support +this functionality. + +Installation +============ + +To install this module, you need to: + +Download the module and add it to your Odoo addons folder. Afterward, log on to +your Odoo server and go to the Apps menu. Trigger the debug mode and update the +list by clicking on the "Update Apps List" link. Now install the module by +clicking on the install button. + +Another way to install this module is via the package management for Python +(`PyPI `_). + +To install our modules using the package manager make sure +`odoo-autodiscover `_ is installed +correctly. Note that for Odoo version 11.0 and later this is not necessary anymore. +Then open a console and install the module by entering the following command: + +``pip install --extra-index-url https://nexus.mukit.at/repository/odoo/simple `` + +The module name consists of the Odoo version and the module name, where +underscores are replaced by a dash. + +**Module:** + +``odoo-addon-`` + +**Example:** + +``sudo -H pip3 install --extra-index-url https://nexus.mukit.at/repository/odoo/simple odoo13-addon-muk-utils`` + +Once the installation has been successfully completed, the app is already in the +correct folder. Log on to your Odoo server and go to the Apps menu. Trigger the +debug mode and update the list by clicking on the "Update Apps List" link. Now +install the module by clicking on the install button. + +The biggest advantage of this variant is that you can now also update the app +using the "pip" command. To do this, enter the following command in your console: + +``pip install --upgrade --extra-index-url https://nexus.mukit.at/repository/odoo/simple `` + +When the process is finished, restart your server and update the application in +Odoo. The steps are the same as for the installation only the button has changed +from "Install" to "Upgrade". + +You can also view available Apps directly in our `repository `_ +and find a more detailed installation guide on our `website `_. + +For modules licensed under a proprietary license, you will receive the access data after you purchased +the module. If the purchase were made at the Odoo store please contact our `support `_ +with a confirmation of the purchase to receive the corresponding access data. + +Upgrade +============ + +To upgrade this module, you need to: + +Download the module and add it to your Odoo addons folder. Restart the server +and log on to your Odoo server. Select the Apps menu and upgrade the module by +clicking on the upgrade button. + +If you installed the module using the "pip" command, you can also update the +module in the same way. Just type the following command into the console: + +``pip install --upgrade --extra-index-url https://nexus.mukit.at/repository/odoo/simple `` + +When the process is finished, restart your server and update the application in +Odoo, just like you would normally. + + +Configuration +============= + +No additional configuration is needed to use this module. + +Usage +===== + +This module has no direct visible effect on the system. It adds a new route +which can be used by modules which add fields with stream capability. + +Credit +====== + +Contributors +------------ + +* Mathias Markl + +Images +------ + +Some pictures are based on or inspired by the icon set of Font Awesome: + +* `Font Awesome `_ + +Author & Maintainer +------------------- + +This module is maintained by the `MuK IT GmbH `_. + +MuK IT is an Austrian company specialized in customizing and extending Odoo. +We develop custom solutions for your individual needs to help you focus on +your strength and expertise to grow your business. + +If you want to get in touch please contact us via `mail `_ +or visit our `website `_. diff --git a/muk_fields_stream/i18n/ar.po b/muk_fields_stream/i18n/ar.po new file mode 100644 index 0000000..cce4a4e --- /dev/null +++ b/muk_fields_stream/i18n/ar.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:53+0000\n" +"PO-Revision-Date: 2019-07-12 23:53+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/de.po b/muk_fields_stream/i18n/de.po new file mode 100644 index 0000000..1717864 --- /dev/null +++ b/muk_fields_stream/i18n/de.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:54+0000\n" +"PO-Revision-Date: 2019-07-12 23:54+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/es.po b/muk_fields_stream/i18n/es.po new file mode 100644 index 0000000..1717864 --- /dev/null +++ b/muk_fields_stream/i18n/es.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:54+0000\n" +"PO-Revision-Date: 2019-07-12 23:54+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/fr.po b/muk_fields_stream/i18n/fr.po new file mode 100644 index 0000000..1717864 --- /dev/null +++ b/muk_fields_stream/i18n/fr.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:54+0000\n" +"PO-Revision-Date: 2019-07-12 23:54+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/hi.po b/muk_fields_stream/i18n/hi.po new file mode 100644 index 0000000..1717864 --- /dev/null +++ b/muk_fields_stream/i18n/hi.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:54+0000\n" +"PO-Revision-Date: 2019-07-12 23:54+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/muk_fields_stream.pot b/muk_fields_stream/i18n/muk_fields_stream.pot new file mode 100644 index 0000000..cce4a4e --- /dev/null +++ b/muk_fields_stream/i18n/muk_fields_stream.pot @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:53+0000\n" +"PO-Revision-Date: 2019-07-12 23:53+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/nl.po b/muk_fields_stream/i18n/nl.po new file mode 100644 index 0000000..c29f50a --- /dev/null +++ b/muk_fields_stream/i18n/nl.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:55+0000\n" +"PO-Revision-Date: 2019-07-12 23:55+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/pt.po b/muk_fields_stream/i18n/pt.po new file mode 100644 index 0000000..c29f50a --- /dev/null +++ b/muk_fields_stream/i18n/pt.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:55+0000\n" +"PO-Revision-Date: 2019-07-12 23:55+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/i18n/ru.po b/muk_fields_stream/i18n/ru.po new file mode 100644 index 0000000..c29f50a --- /dev/null +++ b/muk_fields_stream/i18n/ru.po @@ -0,0 +1,15 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0-20190522\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-07-12 23:55+0000\n" +"PO-Revision-Date: 2019-07-12 23:55+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/muk_fields_stream/models/__init__.py b/muk_fields_stream/models/__init__.py new file mode 100644 index 0000000..2ebdfee --- /dev/null +++ b/muk_fields_stream/models/__init__.py @@ -0,0 +1,23 @@ +################################################################################### +# +# Copyright (c) 2017-2019 MuK IT GmbH. +# +# This file is part of MuK Binary Stream Support +# (see https://mukit.at). +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# +################################################################################### + +from . import ir_http diff --git a/muk_fields_stream/models/ir_http.py b/muk_fields_stream/models/ir_http.py new file mode 100644 index 0000000..0b6464f --- /dev/null +++ b/muk_fields_stream/models/ir_http.py @@ -0,0 +1,132 @@ +################################################################################### +# +# Copyright (c) 2017-2019 MuK IT GmbH. +# +# This file is part of MuK Binary Stream Support +# (see https://mukit.at). +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see . +# +################################################################################### + +import io +import logging +import mimetypes + +from odoo import models + +_logger = logging.getLogger(__name__) + + +class IrHttp(models.AbstractModel): + + _inherit = "ir.http" + + # ---------------------------------------------------------- + # Helper + # ---------------------------------------------------------- + + def _check_streamable(record, field): + return False + + def _stream_content( + self, + record, + field="content", + filename=None, + filename_field="content_fname", + default_mimetype="application/octet-stream", + ): + if self._check_streamable(record, field): + mimetype = "mimetype" in record and record.mimetype or False + filehash = "checksum" in record and record["checksum"] or False + stream = record.with_context({"stream": True})[field] or io.BytesIO() + if not filename: + if filename_field in record: + filename = record[filename_field] + if not filename: + filename = "{}-{}-{}".format(record._name, record.id, field) + if not mimetype and filename: + mimetype = mimetypes.guess_type(filename)[0] + if not mimetype: + mimetype = default_mimetype + _, existing_extension = os.path.splitext(filename) + if not existing_extension: + extension = mimetypes.guess_extension(mimetype) + if extension: + filename = "{}{}".format(filename, extension) + if not filehash and stream: + filehash = record.with_context({"checksum": True})[field] + return stream and 200 or 404, stream, filename, mimetype, filehash + return (404, [], None) + + # ---------------------------------------------------------- + # Functions + # ---------------------------------------------------------- + + def binary_stream( + self, + xmlid=None, + model=None, + id=None, + field="content", + unique=False, + filename=None, + filename_field="content_fname", + download=False, + mimetype=None, + default_mimetype="application/octet-stream", + access_token=None, + ): + """ Get file, attachment or downloadable content + + If the ``xmlid`` and ``id`` parameter is omitted, fetches the default value for the + binary field (via ``default_get``), otherwise fetches the field for + that precise record. + + :param str xmlid: xmlid of the record + :param str model: name of the model to fetch the binary from + :param int id: id of the record from which to fetch the binary + :param str field: binary field + :param bool unique: add a max-age for the cache control + :param str filename: choose a filename + :param str filename_field: if not create an filename with model-id-field + :param bool download: apply headers to download the file + :param str mimetype: mintype of the field (for headers) + :param str default_mimetype: default mintype if no mintype found + :param str access_token: optional token for unauthenticated access + :returns: (status, headers, content) + """ + record, status = self._get_record_and_check( + xmlid=xmlid, model=model, id=id, field=field, access_token=access_token + ) + if not record: + return (status or 404, [], None) + status, stream, filename, mimetype, filehash = self._stream_content( + record, + field=field, + filename=filename, + filename_field=filename_field, + default_mimetype="application/octet-stream", + ) + status, headers, stream = self._binary_set_headers( + status, + stream, + filename, + mimetype, + unique, + filehash=filehash, + download=download, + ) + return status, headers, stream diff --git a/muk_fields_stream/static/description/banner.png b/muk_fields_stream/static/description/banner.png new file mode 100644 index 0000000..19e9ad0 Binary files /dev/null and b/muk_fields_stream/static/description/banner.png differ diff --git a/muk_fields_stream/static/description/icon.png b/muk_fields_stream/static/description/icon.png new file mode 100644 index 0000000..d6d9278 Binary files /dev/null and b/muk_fields_stream/static/description/icon.png differ diff --git a/muk_fields_stream/static/description/icon.svg b/muk_fields_stream/static/description/icon.svg new file mode 100644 index 0000000..42f8a2e --- /dev/null +++ b/muk_fields_stream/static/description/icon.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/muk_fields_stream/static/description/index.html b/muk_fields_stream/static/description/index.html new file mode 100644 index 0000000..509918e --- /dev/null +++ b/muk_fields_stream/static/description/index.html @@ -0,0 +1,172 @@ +
+
+

MuK Binary Stream Support

+

Support for Binary Streams

+

+ MuK IT GmbH - www.mukit.at +

+
+
+ +
+
+
+

Overview

+
+

This module adds a new http route which allows to download + binary data as a stream. This is especially useful for large files, + because they don't fit in the ram as a whole and can easily cause + an error because ram limits are exceeded. This module serves as a + basis for a number of extensions that add fields to Odoo which + support this functionality.

+
+
+
+
+ +
+ +
+ +
+
+
+ + + +
+
+
+ +
+

Help and Support

+
+ Feel free to contact us, if you need any help with your Odoo integration or + addiontal features. +
+ + +
diff --git a/muk_fields_stream/static/description/logo.png b/muk_fields_stream/static/description/logo.png new file mode 100644 index 0000000..9427ce3 Binary files /dev/null and b/muk_fields_stream/static/description/logo.png differ diff --git a/muk_fields_stream/static/description/preview.png b/muk_fields_stream/static/description/preview.png new file mode 100644 index 0000000..1deb1cc Binary files /dev/null and b/muk_fields_stream/static/description/preview.png differ diff --git a/muk_fields_stream/static/description/service_customization.png b/muk_fields_stream/static/description/service_customization.png new file mode 100644 index 0000000..3eac664 Binary files /dev/null and b/muk_fields_stream/static/description/service_customization.png differ diff --git a/muk_fields_stream/static/description/service_development.png b/muk_fields_stream/static/description/service_development.png new file mode 100644 index 0000000..580d460 Binary files /dev/null and b/muk_fields_stream/static/description/service_development.png differ diff --git a/muk_fields_stream/static/description/service_implementation.png b/muk_fields_stream/static/description/service_implementation.png new file mode 100644 index 0000000..d64b66b Binary files /dev/null and b/muk_fields_stream/static/description/service_implementation.png differ diff --git a/muk_fields_stream/static/description/service_integration.png b/muk_fields_stream/static/description/service_integration.png new file mode 100644 index 0000000..76c5e80 Binary files /dev/null and b/muk_fields_stream/static/description/service_integration.png differ diff --git a/muk_fields_stream/static/description/service_support.png b/muk_fields_stream/static/description/service_support.png new file mode 100644 index 0000000..4c530fa Binary files /dev/null and b/muk_fields_stream/static/description/service_support.png differ