From 31b9c39f8cb952568b4c09a58a006cae3713519d Mon Sep 17 00:00:00 2001 From: Boris Gallet Date: Thu, 27 Feb 2025 09:17:51 +0100 Subject: [PATCH 1/5] [NEW] account_move_attachement_zipped_download --- .../.gitignore | 2 + account_attachement_zipped_download/LICENSE | 661 ++++++++++++++++++ .../README.rst | 44 ++ .../__init__.py | 1 + .../__manifest__.py | 30 + .../i18n/fr.po | 21 + .../models/__init__.py | 1 + .../models/account_move.py | 6 + .../security/ir.model.access.csv | 1 + .../security/security.xml | 32 + .../download_account_move_attachments.xml | 16 + .../.gitignore | 2 + .../LICENSE | 661 ++++++++++++++++++ .../README.rst | 44 ++ .../__init__.py | 1 + .../__manifest__.py | 30 + .../i18n/fr.po | 21 + .../models/__init__.py | 1 + .../models/account_move.py | 6 + .../security/ir.model.access.csv | 1 + .../security/security.xml | 32 + .../download_account_move_attachments.xml | 16 + 22 files changed, 1630 insertions(+) create mode 100644 account_attachement_zipped_download/.gitignore create mode 100644 account_attachement_zipped_download/LICENSE create mode 100644 account_attachement_zipped_download/README.rst create mode 100644 account_attachement_zipped_download/__init__.py create mode 100644 account_attachement_zipped_download/__manifest__.py create mode 100644 account_attachement_zipped_download/i18n/fr.po create mode 100644 account_attachement_zipped_download/models/__init__.py create mode 100644 account_attachement_zipped_download/models/account_move.py create mode 100644 account_attachement_zipped_download/security/ir.model.access.csv create mode 100644 account_attachement_zipped_download/security/security.xml create mode 100644 account_attachement_zipped_download/views/download_account_move_attachments.xml create mode 100644 account_move_attachement_zipped_download/.gitignore create mode 100644 account_move_attachement_zipped_download/LICENSE create mode 100644 account_move_attachement_zipped_download/README.rst create mode 100644 account_move_attachement_zipped_download/__init__.py create mode 100644 account_move_attachement_zipped_download/__manifest__.py create mode 100644 account_move_attachement_zipped_download/i18n/fr.po create mode 100644 account_move_attachement_zipped_download/models/__init__.py create mode 100644 account_move_attachement_zipped_download/models/account_move.py create mode 100644 account_move_attachement_zipped_download/security/ir.model.access.csv create mode 100644 account_move_attachement_zipped_download/security/security.xml create mode 100644 account_move_attachement_zipped_download/views/download_account_move_attachments.xml diff --git a/account_attachement_zipped_download/.gitignore b/account_attachement_zipped_download/.gitignore new file mode 100644 index 0000000..df8a896 --- /dev/null +++ b/account_attachement_zipped_download/.gitignore @@ -0,0 +1,2 @@ +*.*~ +*pyc \ No newline at end of file diff --git a/account_attachement_zipped_download/LICENSE b/account_attachement_zipped_download/LICENSE new file mode 100644 index 0000000..0ad25db --- /dev/null +++ b/account_attachement_zipped_download/LICENSE @@ -0,0 +1,661 @@ + GNU AFFERO GENERAL PUBLIC LICENSE + Version 3, 19 November 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. + + Preamble + + The GNU Affero General Public License is a free, copyleft license for +software and other kinds of works, specifically designed to ensure +cooperation with the community in the case of network server software. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +our General Public Licenses are intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + Developers that use our General Public Licenses protect your rights +with two steps: (1) assert copyright on the software, and (2) offer +you this License which gives you legal permission to copy, distribute +and/or modify the software. + + A secondary benefit of defending all users' freedom is that +improvements made in alternate versions of the program, if they +receive widespread use, become available for other developers to +incorporate. Many developers of free software are heartened and +encouraged by the resulting cooperation. However, in the case of +software used on network servers, this result may fail to come about. +The GNU General Public License permits making a modified version and +letting the public access it on a server without ever releasing its +source code to the public. + + The GNU Affero General Public License is designed specifically to +ensure that, in such cases, the modified source code becomes available +to the community. It requires the operator of a network server to +provide the source code of the modified version running there to the +users of that server. Therefore, public use of a modified version, on +a publicly accessible server, gives the public access to the source +code of the modified version. + + An older license, called the Affero General Public License and +published by Affero, was designed to accomplish similar goals. This is +a different license, not a version of the Affero GPL, but Affero has +released a new version of the Affero GPL which permits relicensing under +this license. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU Affero General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Remote Network Interaction; Use with the GNU General Public License. + + Notwithstanding any other provision of this License, if you modify the +Program, your modified version must prominently offer all users +interacting with it remotely through a computer network (if your version +supports such interaction) an opportunity to receive the Corresponding +Source of your version by providing access to the Corresponding Source +from a network server at no charge, through some standard or customary +means of facilitating copying of software. This Corresponding Source +shall include the Corresponding Source for any work covered by version 3 +of the GNU General Public License that is incorporated pursuant to the +following paragraph. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the work with which it is combined will remain governed by version +3 of the GNU General Public License. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU Affero 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 +Program specifies that a certain numbered version of the GNU Affero General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU Affero General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU Affero General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero 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 Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If your software can interact with users remotely through a computer +network, you should also make sure that it provides a way for users to +get its source. For example, if your program is a web application, its +interface could display a "Source" link that leads users to an archive +of the code. There are many ways you could offer source, and different +solutions will be better for different programs; see section 13 for the +specific requirements. + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU AGPL, see +. diff --git a/account_attachement_zipped_download/README.rst b/account_attachement_zipped_download/README.rst new file mode 100644 index 0000000..e1d1b86 --- /dev/null +++ b/account_attachement_zipped_download/README.rst @@ -0,0 +1,44 @@ +=============== +account_attachement_zipped_download +=============== + +custom attachments zipped download for account_move model + +Installation +============ + +Use Odoo normal module installation procedure to install +``account_attachement_zipped_download``. + +Known issues / Roadmap +====================== + +None yet. + +Bug Tracker +=========== + +Bugs are tracked on `our issues website `_. In case of +trouble, please check there if your issue has already been +reported. If you spotted it first, help us smashing it by providing a +detailed and welcomed feedback. + +Credits +======= + +Contributors +------------ + +* Boris Gallet - `Email` - `Github` + +Funders +------- + +The development of this module has been financially supported by: +* Elabore (https://elabore.coop) + + +Maintainer +---------- + +This module is maintained by Elabore. \ No newline at end of file diff --git a/account_attachement_zipped_download/__init__.py b/account_attachement_zipped_download/__init__.py new file mode 100644 index 0000000..0650744 --- /dev/null +++ b/account_attachement_zipped_download/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/account_attachement_zipped_download/__manifest__.py b/account_attachement_zipped_download/__manifest__.py new file mode 100644 index 0000000..cc47425 --- /dev/null +++ b/account_attachement_zipped_download/__manifest__.py @@ -0,0 +1,30 @@ +# Copyright 2025 Boris Gallet () +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "account_attachement_zipped_download", + "version": "16.0.1.0.0", + "author": "Elabore", + "website": "https://elabore.coop", + "maintainer": "Boris Gallet", + "license": "AGPL-3", + "category": "Tools", + "summary": "Extend attachments zipped download for account_move model", + # any module necessary for this one to work correctly + "depends": ["base", "account", "attachment_zipped_download"], + "qweb": [], + "external_dependencies": { + "python": [], + }, + # always loaded + "data": ["views/download_account_move_attachments.xml"], + # only loaded in demonstration mode + "demo": [], + "js": [], + "css": [], + "installable": True, + # Install this module automatically if all dependency have been previously + # and independently installed. Used for synergetic or glue modules. + "auto_install": False, + "application": False, +} diff --git a/account_attachement_zipped_download/i18n/fr.po b/account_attachement_zipped_download/i18n/fr.po new file mode 100644 index 0000000..78c45a8 --- /dev/null +++ b/account_attachement_zipped_download/i18n/fr.po @@ -0,0 +1,21 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * account_attachement_zipped_download +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2025-02-27 08:11+0000\n" +"PO-Revision-Date: 2025-02-27 08:11+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" + +#. module: account_attachement_zipped_download +#: model:ir.actions.server,name:account_attachement_zipped_download.action_download_account_move_attachements +msgid "Download attachments" +msgstr "Télécharger les pièces jointes" \ No newline at end of file diff --git a/account_attachement_zipped_download/models/__init__.py b/account_attachement_zipped_download/models/__init__.py new file mode 100644 index 0000000..9c0a421 --- /dev/null +++ b/account_attachement_zipped_download/models/__init__.py @@ -0,0 +1 @@ +from . import account_move diff --git a/account_attachement_zipped_download/models/account_move.py b/account_attachement_zipped_download/models/account_move.py new file mode 100644 index 0000000..f944b3f --- /dev/null +++ b/account_attachement_zipped_download/models/account_move.py @@ -0,0 +1,6 @@ +from odoo import models + + +class AccountMove(models.Model): + _name = "account.move" + _inherit = ["account.move", "ir.attachment.action_download"] diff --git a/account_attachement_zipped_download/security/ir.model.access.csv b/account_attachement_zipped_download/security/ir.model.access.csv new file mode 100644 index 0000000..301b7da --- /dev/null +++ b/account_attachement_zipped_download/security/ir.model.access.csv @@ -0,0 +1 @@ +id,name,model_id/id,group_id/id,perm_read,perm_write,perm_create,perm_unlink diff --git a/account_attachement_zipped_download/security/security.xml b/account_attachement_zipped_download/security/security.xml new file mode 100644 index 0000000..7aee4ab --- /dev/null +++ b/account_attachement_zipped_download/security/security.xml @@ -0,0 +1,32 @@ + + + + + + + + + diff --git a/account_attachement_zipped_download/views/download_account_move_attachments.xml b/account_attachement_zipped_download/views/download_account_move_attachments.xml new file mode 100644 index 0000000..bc0bf89 --- /dev/null +++ b/account_attachement_zipped_download/views/download_account_move_attachments.xml @@ -0,0 +1,16 @@ + + + + Download attachments + + + list + code + + action = records.action_download_attachments() + + + diff --git a/account_move_attachement_zipped_download/.gitignore b/account_move_attachement_zipped_download/.gitignore new file mode 100644 index 0000000..df8a896 --- /dev/null +++ b/account_move_attachement_zipped_download/.gitignore @@ -0,0 +1,2 @@ +*.*~ +*pyc \ No newline at end of file diff --git a/account_move_attachement_zipped_download/LICENSE b/account_move_attachement_zipped_download/LICENSE new file mode 100644 index 0000000..0ad25db --- /dev/null +++ b/account_move_attachement_zipped_download/LICENSE @@ -0,0 +1,661 @@ + GNU AFFERO GENERAL PUBLIC LICENSE + Version 3, 19 November 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. + + Preamble + + The GNU Affero General Public License is a free, copyleft license for +software and other kinds of works, specifically designed to ensure +cooperation with the community in the case of network server software. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +our General Public Licenses are intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + Developers that use our General Public Licenses protect your rights +with two steps: (1) assert copyright on the software, and (2) offer +you this License which gives you legal permission to copy, distribute +and/or modify the software. + + A secondary benefit of defending all users' freedom is that +improvements made in alternate versions of the program, if they +receive widespread use, become available for other developers to +incorporate. Many developers of free software are heartened and +encouraged by the resulting cooperation. However, in the case of +software used on network servers, this result may fail to come about. +The GNU General Public License permits making a modified version and +letting the public access it on a server without ever releasing its +source code to the public. + + The GNU Affero General Public License is designed specifically to +ensure that, in such cases, the modified source code becomes available +to the community. It requires the operator of a network server to +provide the source code of the modified version running there to the +users of that server. Therefore, public use of a modified version, on +a publicly accessible server, gives the public access to the source +code of the modified version. + + An older license, called the Affero General Public License and +published by Affero, was designed to accomplish similar goals. This is +a different license, not a version of the Affero GPL, but Affero has +released a new version of the Affero GPL which permits relicensing under +this license. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU Affero General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Remote Network Interaction; Use with the GNU General Public License. + + Notwithstanding any other provision of this License, if you modify the +Program, your modified version must prominently offer all users +interacting with it remotely through a computer network (if your version +supports such interaction) an opportunity to receive the Corresponding +Source of your version by providing access to the Corresponding Source +from a network server at no charge, through some standard or customary +means of facilitating copying of software. This Corresponding Source +shall include the Corresponding Source for any work covered by version 3 +of the GNU General Public License that is incorporated pursuant to the +following paragraph. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the work with which it is combined will remain governed by version +3 of the GNU General Public License. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU Affero 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 +Program specifies that a certain numbered version of the GNU Affero General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU Affero General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU Affero General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero 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 Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If your software can interact with users remotely through a computer +network, you should also make sure that it provides a way for users to +get its source. For example, if your program is a web application, its +interface could display a "Source" link that leads users to an archive +of the code. There are many ways you could offer source, and different +solutions will be better for different programs; see section 13 for the +specific requirements. + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU AGPL, see +. diff --git a/account_move_attachement_zipped_download/README.rst b/account_move_attachement_zipped_download/README.rst new file mode 100644 index 0000000..0b9501c --- /dev/null +++ b/account_move_attachement_zipped_download/README.rst @@ -0,0 +1,44 @@ +=============== +account_move_attachement_zipped_download +=============== + +custom attachments zipped download for account_move model + +Installation +============ + +Use Odoo normal module installation procedure to install +``account_move_attachement_zipped_download``. + +Known issues / Roadmap +====================== + +None yet. + +Bug Tracker +=========== + +Bugs are tracked on `our issues website `_. In case of +trouble, please check there if your issue has already been +reported. If you spotted it first, help us smashing it by providing a +detailed and welcomed feedback. + +Credits +======= + +Contributors +------------ + +* Boris Gallet - `Email` - `Github` + +Funders +------- + +The development of this module has been financially supported by: +* Elabore (https://elabore.coop) + + +Maintainer +---------- + +This module is maintained by Elabore. \ No newline at end of file diff --git a/account_move_attachement_zipped_download/__init__.py b/account_move_attachement_zipped_download/__init__.py new file mode 100644 index 0000000..0650744 --- /dev/null +++ b/account_move_attachement_zipped_download/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/account_move_attachement_zipped_download/__manifest__.py b/account_move_attachement_zipped_download/__manifest__.py new file mode 100644 index 0000000..79571a3 --- /dev/null +++ b/account_move_attachement_zipped_download/__manifest__.py @@ -0,0 +1,30 @@ +# Copyright 2025 Boris Gallet () +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "account_move_attachement_zipped_download", + "version": "16.0.1.0.0", + "author": "Elabore", + "website": "https://elabore.coop", + "maintainer": "Boris Gallet", + "license": "AGPL-3", + "category": "Tools", + "summary": "Extend attachments zipped download for account_move model", + # any module necessary for this one to work correctly + "depends": ["base", "account", "attachment_zipped_download"], + "qweb": [], + "external_dependencies": { + "python": [], + }, + # always loaded + "data": ["views/download_account_move_attachments.xml"], + # only loaded in demonstration mode + "demo": [], + "js": [], + "css": [], + "installable": True, + # Install this module automatically if all dependency have been previously + # and independently installed. Used for synergetic or glue modules. + "auto_install": False, + "application": False, +} diff --git a/account_move_attachement_zipped_download/i18n/fr.po b/account_move_attachement_zipped_download/i18n/fr.po new file mode 100644 index 0000000..ff3886f --- /dev/null +++ b/account_move_attachement_zipped_download/i18n/fr.po @@ -0,0 +1,21 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * account_move_attachement_zipped_download +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2025-02-27 08:11+0000\n" +"PO-Revision-Date: 2025-02-27 08:11+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" + +#. module: account_move_attachement_zipped_download +#: model:ir.actions.server,name:account_move_attachement_zipped_download.action_download_account_move_attachements +msgid "Download attachments" +msgstr "Télécharger les pièces jointes" \ No newline at end of file diff --git a/account_move_attachement_zipped_download/models/__init__.py b/account_move_attachement_zipped_download/models/__init__.py new file mode 100644 index 0000000..9c0a421 --- /dev/null +++ b/account_move_attachement_zipped_download/models/__init__.py @@ -0,0 +1 @@ +from . import account_move diff --git a/account_move_attachement_zipped_download/models/account_move.py b/account_move_attachement_zipped_download/models/account_move.py new file mode 100644 index 0000000..f944b3f --- /dev/null +++ b/account_move_attachement_zipped_download/models/account_move.py @@ -0,0 +1,6 @@ +from odoo import models + + +class AccountMove(models.Model): + _name = "account.move" + _inherit = ["account.move", "ir.attachment.action_download"] diff --git a/account_move_attachement_zipped_download/security/ir.model.access.csv b/account_move_attachement_zipped_download/security/ir.model.access.csv new file mode 100644 index 0000000..301b7da --- /dev/null +++ b/account_move_attachement_zipped_download/security/ir.model.access.csv @@ -0,0 +1 @@ +id,name,model_id/id,group_id/id,perm_read,perm_write,perm_create,perm_unlink diff --git a/account_move_attachement_zipped_download/security/security.xml b/account_move_attachement_zipped_download/security/security.xml new file mode 100644 index 0000000..2797d07 --- /dev/null +++ b/account_move_attachement_zipped_download/security/security.xml @@ -0,0 +1,32 @@ + + + + + + + + + diff --git a/account_move_attachement_zipped_download/views/download_account_move_attachments.xml b/account_move_attachement_zipped_download/views/download_account_move_attachments.xml new file mode 100644 index 0000000..bc0bf89 --- /dev/null +++ b/account_move_attachement_zipped_download/views/download_account_move_attachments.xml @@ -0,0 +1,16 @@ + + + + Download attachments + + + list + code + + action = records.action_download_attachments() + + + -- 2.49.1 From 37142bfa98d53ca8f902eb5b6586a83a7f4d7391 Mon Sep 17 00:00:00 2001 From: Laetitia Da Costa Date: Mon, 16 Sep 2024 17:16:39 +0200 Subject: [PATCH 2/5] [ADD]mandates_bank_accounts_portal --- partner_bank_account_portal/.gitignore | 2 + partner_bank_account_portal/README.rst | 49 +++++ partner_bank_account_portal/__init__.py | 3 + partner_bank_account_portal/__manifest__.py | 48 +++++ .../controllers/__init__.py | 4 + .../controllers/portal_my_bank_account.py | 159 +++++++++++++++ .../controllers/portal_my_bank_accounts.py | 92 +++++++++ .../controllers/portal_my_mandate.py | 152 ++++++++++++++ .../controllers/portal_my_mandates.py | 72 +++++++ partner_bank_account_portal/i18n/fr.po | 192 ++++++++++++++++++ .../models/__init__.py | 2 + .../models/res_partner_bank.py | 17 ++ .../security/ir.model.access.csv | 4 + .../security/members_security.xml | 34 ++++ .../views/portal_my_bank_account_template.xml | 82 ++++++++ .../portal_my_bank_accounts_template.xml | 54 +++++ .../portal_my_contract_template_inherit.xml | 18 ++ .../views/portal_my_home_template.xml | 41 ++++ .../views/portal_my_mandate_template.xml | 60 ++++++ .../views/portal_my_mandates_template.xml | 57 ++++++ 20 files changed, 1142 insertions(+) create mode 100644 partner_bank_account_portal/.gitignore create mode 100644 partner_bank_account_portal/README.rst create mode 100644 partner_bank_account_portal/__init__.py create mode 100644 partner_bank_account_portal/__manifest__.py create mode 100644 partner_bank_account_portal/controllers/__init__.py create mode 100644 partner_bank_account_portal/controllers/portal_my_bank_account.py create mode 100644 partner_bank_account_portal/controllers/portal_my_bank_accounts.py create mode 100644 partner_bank_account_portal/controllers/portal_my_mandate.py create mode 100644 partner_bank_account_portal/controllers/portal_my_mandates.py create mode 100644 partner_bank_account_portal/i18n/fr.po create mode 100644 partner_bank_account_portal/models/__init__.py create mode 100644 partner_bank_account_portal/models/res_partner_bank.py create mode 100644 partner_bank_account_portal/security/ir.model.access.csv create mode 100644 partner_bank_account_portal/security/members_security.xml create mode 100644 partner_bank_account_portal/views/portal_my_bank_account_template.xml create mode 100644 partner_bank_account_portal/views/portal_my_bank_accounts_template.xml create mode 100644 partner_bank_account_portal/views/portal_my_contract_template_inherit.xml create mode 100644 partner_bank_account_portal/views/portal_my_home_template.xml create mode 100644 partner_bank_account_portal/views/portal_my_mandate_template.xml create mode 100644 partner_bank_account_portal/views/portal_my_mandates_template.xml diff --git a/partner_bank_account_portal/.gitignore b/partner_bank_account_portal/.gitignore new file mode 100644 index 0000000..6da5887 --- /dev/null +++ b/partner_bank_account_portal/.gitignore @@ -0,0 +1,2 @@ +*.*~ +*pyc diff --git a/partner_bank_account_portal/README.rst b/partner_bank_account_portal/README.rst new file mode 100644 index 0000000..f5aa8c2 --- /dev/null +++ b/partner_bank_account_portal/README.rst @@ -0,0 +1,49 @@ +=============== +partner_bank_account_portal +=============== + +Provide portal pages and forms to manage partner's contract, bank accounts and mandates from portal home space. + +Installation +============ + +Use Odoo normal module installation procedure to install +``partner_bank_account_portal``. + +Description +=========== + +Provide portal pages and forms to manage partner's bank accounts and mandates from portal home space. +Also add the mandate in contract portal view + +Known issues / Roadmap +====================== + +None yet. +Bug Tracker +=========== + +Bugs are tracked on `our issues website `_. In case of +trouble, please check there if your issue has already been +reported. If you spotted it first, help us smashing it by providing a +detailed and welcomed feedback. + +Credits +======= + +Contributors +------------ + +* Laetitia Da Costa + +Funders +------- + +The development of this module has been financially supported by: +* Elabore (https://elabore.coop) + + +Maintainer +---------- + +This module is maintained by Elabore. \ No newline at end of file diff --git a/partner_bank_account_portal/__init__.py b/partner_bank_account_portal/__init__.py new file mode 100644 index 0000000..4dcac26 --- /dev/null +++ b/partner_bank_account_portal/__init__.py @@ -0,0 +1,3 @@ + +from . import controllers +from . import models diff --git a/partner_bank_account_portal/__manifest__.py b/partner_bank_account_portal/__manifest__.py new file mode 100644 index 0000000..847eede --- /dev/null +++ b/partner_bank_account_portal/__manifest__.py @@ -0,0 +1,48 @@ +# Copyright 2022 Stéphan Sainléger (Elabore) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "Mandates and bank accounts portal", + "version": "16.0.1.0.0", + "author": "Elabore", + "website": "https://elabore.coop", + "maintainer": "Laetitia Da Costa", + "license": "AGPL-3", + "category": "Tools", + "summary": "Provide portal pages and forms to manage partner's bank accounts and mandates from portal home space.", + # any module necessary for this one to work correctly + "depends": [ + "base", + "account", + "portal", + "website", + "account_banking_mandate", + "contract", + "account_payment_order", + "contract_mandate", + ], + "qweb": [], + "external_dependencies": { + "python": [], + }, + # always loaded + "data": [ + "security/members_security.xml", + "security/ir.model.access.csv", + "views/portal_my_home_template.xml", + "views/portal_my_bank_accounts_template.xml", + "views/portal_my_bank_account_template.xml", + "views/portal_my_mandates_template.xml", + "views/portal_my_mandate_template.xml", + "views/portal_my_contract_template_inherit.xml", + ], + # only loaded in demonstration mode + "demo": [], + "js": [], + "css": [], + "installable": True, + # Install this module automatically if all dependency have been previously + # and independently installed. Used for synergetic or glue modules. + "auto_install": False, + "application": False, +} \ No newline at end of file diff --git a/partner_bank_account_portal/controllers/__init__.py b/partner_bank_account_portal/controllers/__init__.py new file mode 100644 index 0000000..7250f27 --- /dev/null +++ b/partner_bank_account_portal/controllers/__init__.py @@ -0,0 +1,4 @@ +from . import portal_my_bank_accounts +from . import portal_my_bank_account +from . import portal_my_mandates +from . import portal_my_mandate diff --git a/partner_bank_account_portal/controllers/portal_my_bank_account.py b/partner_bank_account_portal/controllers/portal_my_bank_account.py new file mode 100644 index 0000000..8fe1132 --- /dev/null +++ b/partner_bank_account_portal/controllers/portal_my_bank_account.py @@ -0,0 +1,159 @@ +# Copyright 2020 Lokavaluto () +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +import base64 +from odoo import http, tools, _ +from odoo.exceptions import AccessError, MissingError +from odoo.http import request +from odoo.addons.portal.controllers.portal import CustomerPortal + + +class CustomerPortalBankAccount(CustomerPortal): + + def _bank_account_get_page_view_values(self, bank_account, access_token, **kwargs): + values = { + "page_name": "bank_account", + "bank_account": bank_account, + } + return self._get_page_view_values( + bank_account, access_token, values, "my_bank_accounts_history", False, **kwargs + ) + + def _details_bank_account_form_validate(self, data, bank_account_id): + error = dict() + error_message = [] + # public name uniqueness + if data.get("public_name") and request.env["res.partner"].sudo().search( + [ + ("name", "=", data.get("public_name")), + ("is_public_profile", "=", True), + ("contact_id", "!=", bank_account_id), + ] + ): + error["public_name"] = "error" + error_message.append( + _("This public name is already used, please find an other idea.") + ) + + # email validation + if data.get("email") and not tools.single_email_re.match(data.get("email")): + error["email"] = "error" + error_message.append( + _("Invalid Email! Please enter a valid email address.") + ) + return error, error_message + + def _get_bank_account_fields(self): + fields = [ + "acc_number", + "acc_holder_name", + ] + return fields + + def _get_id_fields(self): + fields = [ + "bank_id", + ] + return fields + + def _get_main_boolean_bank_account_fields(self): + '''Provides the fields for which we must check the presence + in form's kw to know the value to save in the partner field. + All of them MUST start with "main_".''' + fields = [] + return fields + + def _transform_res_partner_fields(self, kw, bank_account_fields, prefix=""): + '''Transforms kw's values in res_partner fields and values''' + return {key[len(prefix):]: kw[key] for key in bank_account_fields if key in kw} + + def _cast_id_fields(self, kw, id_fields): + '''Cast ids fields in kw's values into a integer''' + result = {} + for key in id_fields: + if key in kw: + if kw[key] == '': + result[key] = None + elif not isinstance(kw[key], int): + result[key] = int(kw[key]) + else: + result[key] = kw[key] + return result + + def _add_boolean_values(self, values, kw, boolean_fields, prefix=""): + for key in boolean_fields: + values.update( + { + key[len(prefix):]: kw.get(key, "off") == "on", + } + ) + return values + + def _get_page_saving_bank_account_values(self, kw): + bank_account_fields = self._get_bank_account_fields() + values = self._transform_res_partner_fields(kw, bank_account_fields) + if kw["bank_id"] == '': + bank_id = None + else: + bank_id = int(kw["bank_id"]) + values.update({"bank_id":bank_id}) + return values + + @http.route( + ["/my/bank_account/", "/my/bank_account/save"], + type="http", + auth="user", + website=True, + ) + def portal_my_bank_account( + self,bank_account_id=None, access_token=None, redirect=None, **kw + ): + # The following condition is to transform profile_id to an int, as it is sent as a string from the templace "portal_my_profile" + # TODO: find a better way to retrieve the profile_id at form submit step + if not isinstance(bank_account_id, int): + bank_account_id = int(bank_account_id) + + # Check that the user has the right to see this profile + try: + bank_account_sudo = self._document_check_access( + "res.partner.bank", bank_account_id, access_token + ) + except (AccessError, MissingError): + return request.redirect("/my/bank_accounts") + + PartnerBankAccount = request.env["res.partner.bank"] + user = request.env.user + bank_account = PartnerBankAccount.browse(bank_account_id) + + values = self._bank_account_get_page_view_values(bank_account_sudo, access_token, **kw) + values.update( + { + "error": {}, + "error_message": [], + } + ) + if kw and request.httprequest.method == "POST": + # the user has clicked in the Save button to save new data + error, error_message = self._details_bank_account_form_validate(kw, bank_account_id) + values.update({"error": error, "error_message": error_message}) + values.update(kw) + if not error: + # Update main profile + new_values = self._get_page_saving_bank_account_values(kw) + bank_account.sudo().write(new_values) + if redirect: + return request.redirect(redirect) + return request.redirect("/my/bank_accounts") + + # This is just the form page opening. We send all the data needed for the form fields + can_edit_bank_account = user.partner_id == bank_account.partner_id + banks = request.env["res.bank"].sudo().search([]) + + values.update( + { + "bank_account_id": bank_account_id, # Sent in order to retrieve it at submit time + "can_edit_bank_account": can_edit_bank_account, + "banks": banks, + "redirect": "/my/bank_account/" + str(bank_account_id) + "?success=True" + } + ) + return request.render("partner_bank_account_portal.portal_my_bank_account", values) #TODO créer le template portal_my_bank_account.xml diff --git a/partner_bank_account_portal/controllers/portal_my_bank_accounts.py b/partner_bank_account_portal/controllers/portal_my_bank_accounts.py new file mode 100644 index 0000000..749156d --- /dev/null +++ b/partner_bank_account_portal/controllers/portal_my_bank_accounts.py @@ -0,0 +1,92 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import http, _ +from odoo.osv import expression +from odoo.addons.portal.controllers.portal import CustomerPortal, pager as portal_pager +from odoo.exceptions import AccessError, MissingError +from collections import OrderedDict +from odoo.http import request + + +class CustomerPortalBankAccounts(CustomerPortal): + + def _prepare_home_portal_values(self, counters): + values = super()._prepare_home_portal_values(counters) + if 'bank_account_count' in counters: + bank_account_count = request.env['res.partner.bank'].search_count([]) + values['bank_account_count'] = bank_account_count + return values + + def _get_account_searchbar_sortings(self): + res = super()._get_account_searchbar_sortings() + res['acc_number'] = {'label': _('IBAN'), 'order': 'acc_number'} + return res + + + + @http.route(['/my/bank_accounts', '/my/bank_accounts/page/'], type='http', auth="user", website=True) + def portal_my_bank_accounts(self, page=1, date_begin=None, date_end=None, sortby=None, filterby=None, **kw): + values = self._prepare_my_bank_accounts_values(page, date_begin, date_end, sortby, filterby) + + # pager + pager = portal_pager(**values['pager']) + + # content according to pager and archive selected + bank_accounts = values['bank_accounts'](pager['offset']) + request.session['bank_accounts_history'] = bank_accounts.ids[:100] + + values.update({ + 'bank_accounts': bank_accounts, + 'pager': pager, + }) + return request.render("partner_bank_account_portal.portal_my_bank_accounts", values) + + def _get_bank_accounts_domain(self): + return [('active', '=', True)] + + + def _prepare_my_bank_accounts_values(self, page, date_begin, date_end, sortby, filterby, domain=None, url="/my/bank_accounts"): + values = self._prepare_portal_layout_values() + res_partner_bank = request.env['res.partner.bank'] + + domain = expression.AND([ + domain or [], + self._get_bank_accounts_domain(), + ]) + + searchbar_sortings = self._get_account_searchbar_sortings() + # default sort by order + if not sortby: + sortby = 'acc_number' + order = searchbar_sortings[sortby]['order'] + + # default filter by value + if not filterby: + filterby = 'all' + + if date_begin and date_end: + domain += [('create_date', '>', date_begin), ('create_date', '<=', date_end)] + + values.update({ + 'date': date_begin, + # content according to pager and archive selected + # lambda function to get the invoices recordset when the pager will be defined in the main method of a route + 'bank_accounts': lambda pager_offset: ( + res_partner_bank.search(domain, order=order, limit=self._items_per_page, offset=pager_offset) + if res_partner_bank.check_access_rights('read', raise_exception=False) else + res_partner_bank + ), + 'page_name': 'bank_accounts', + 'pager': { # vals to define the pager. + "url": url, + "url_args": {'date_begin': date_begin, 'date_end': date_end, 'sortby': sortby}, + "total": res_partner_bank.search_count(domain) if res_partner_bank.check_access_rights('read', raise_exception=False) else 0, + "page": page, + "step": self._items_per_page, + }, + 'default_url': url, + 'sortby': sortby, + 'filterby': filterby, + }) + return values diff --git a/partner_bank_account_portal/controllers/portal_my_mandate.py b/partner_bank_account_portal/controllers/portal_my_mandate.py new file mode 100644 index 0000000..e3c306a --- /dev/null +++ b/partner_bank_account_portal/controllers/portal_my_mandate.py @@ -0,0 +1,152 @@ +# Copyright 2020 Lokavaluto () +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +import base64 +from odoo import http, tools, _ +from odoo.exceptions import AccessError, MissingError +from odoo.http import request +from odoo.addons.portal.controllers.portal import CustomerPortal + + +class CustomerPortalMandate(CustomerPortal): + + def _mandate_get_page_view_values(self, mandate, access_token, **kwargs): + values = { + "page_name": "mandate", + "mandate": mandate, + } + return self._get_page_view_values( + mandate, access_token, values, "my_mandates_history", False, **kwargs + ) + + def _details_mandate_form_validate(self, data, mandate_id): + error = dict() + error_message = [] + # public name uniqueness + if data.get("public_name") and request.env["res.partner"].sudo().search( + [ + ("name", "=", data.get("public_name")), + ("is_public_profile", "=", True), + ("contact_id", "!=", mandate_id), + ] + ): + error["public_name"] = "error" + error_message.append( + _("This public name is already used, please find an other idea.") + ) + + # email validation + if data.get("email") and not tools.single_email_re.match(data.get("email")): + error["email"] = "error" + error_message.append( + _("Invalid Email! Please enter a valid email address.") + ) + return error, error_message + + def _get_mandate_fields(self): + fields = [ + "unique_mandate_reference", + "signature_date", + "last_debit_date", + "state", + ] + return fields + + def _get_main_boolean_mandate_fields(self): + '''Provides the fields for which we must check the presence + in form's kw to know the value to save in the partner field. + All of them MUST start with "main_".''' + fields = [] + return fields + + def _transform_in_res_partner_fields(self, kw, mandate_fields, prefix=""): + '''Transforms kw's values in res_partner fields and values''' + return {key[len(prefix):]: kw[key] for key in mandate_fields if key in kw} + + def _add_boolean_values(self, values, kw, boolean_fields, prefix=""): + for key in boolean_fields: + values.update( + { + key[len(prefix):]: kw.get(key, "off") == "on", + } + ) + return values + + def _get_page_saving_mandate_values(self, kw): + mandate_fields = self._get_mandate_fields() + values = self._transform_in_res_partner_fields(kw, mandate_fields) + # boolean_fields = self._get_main_boolean_bank_account_fields() + # values = self._add_boolean_values(values, kw, boolean_fields) + return values + + def _get_page_opening_values(self): + # Just retrieve the values to display for Selection fields + countries = request.env["res.country"].sudo().search([]) + values = { + "countries": countries, + } + return values + + @http.route( + ["/my/mandate/", "/my/mandate/save"], + type="http", + auth="user", + website=True, + ) + def portal_my_mandate( + self,mandate_id=None, access_token=None, redirect=None, **kw + ): + # The following condition is to transform profile_id to an int, as it is sent as a string from the templace "portal_my_profile" + # TODO: find a better way to retrieve the profile_id at form submit step + if not isinstance(mandate_id, int): + mandate_id = int(mandate_id) + + # Check that the user has the right to see this profile + try: + mandate_sudo = self._document_check_access( + "account.banking.mandate", mandate_id, access_token + ) + except (AccessError, MissingError): + return request.redirect("/my/mandates") + + Mandate = request.env["account.banking.mandate"] + user = request.env.user + mandate = Mandate.browse(mandate_id) + + values = self._mandate_get_page_view_values(mandate_sudo, access_token, **kw) + values.update( + { + "error": {}, + "error_message": [], + } + ) + if kw and request.httprequest.method == "POST": + # the user has clicked in the Save button to save new data + error, error_message = self._details_mandate_form_validate(kw, mandate_id) + values.update({"error": error, "error_message": error_message}) + values.update(kw) + if not error: + # Update main profile + new_values = self._get_page_saving_mandate_values(kw) + mandate.sudo().write(new_values) + # Update public profile + # new_values = self._get_page_saving_public_structure_values(kw) + # public_profile.sudo().write(new_values) + # Update position profile + # new_values = self._get_page_saving_position_structure_values(kw) + # position_profile.sudo().write(new_values) + # End of updates + if redirect: + return request.redirect(redirect) + return request.redirect("/my/mandates") + + # This is just the form page opening. We send all the data needed for the form fields + can_edit_mandate = user.partner_id == mandate.partner_id + values.update(self._get_page_opening_values()) + values.update( + { + "mandate_id": mandate_id, # Sent in order to retrieve it at submit time + "can_edit_mandate": can_edit_mandate, + "redirect": "/my/mandate/" + str(mandate_id) + "?success=True" + } + ) + return request.render("partner_bank_account_portal.portal_my_mandate", values) #TODO créer le template portal_my_bank_account.xml diff --git a/partner_bank_account_portal/controllers/portal_my_mandates.py b/partner_bank_account_portal/controllers/portal_my_mandates.py new file mode 100644 index 0000000..97a85a1 --- /dev/null +++ b/partner_bank_account_portal/controllers/portal_my_mandates.py @@ -0,0 +1,72 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import http, _ +from odoo.osv import expression +from odoo.addons.portal.controllers.portal import CustomerPortal, pager as portal_pager +from odoo.exceptions import AccessError, MissingError +from collections import OrderedDict +from odoo.http import request + + +class CustomerPortalMandates(CustomerPortal): + + def _prepare_home_portal_values(self, counters): + values = super()._prepare_home_portal_values(counters) + if 'mandate_count' in counters: + mandate_count = request.env['account.banking.mandate'].search_count([]) + values['mandate_count'] = mandate_count + return values + + @http.route(['/my/mandates', '/my/mandates/page/'], type='http', auth="user", website=True) + def portal_mandates(self, page=1, date_begin=None, date_end=None, filterby=None, **kw): + values = self._prepare_my_mandates_values(page, date_begin, date_end) + + # pager + pager = portal_pager(**values['pager']) + + # content according to pager and archive selected + mandates = values['mandates'](pager['offset']) + request.session['mandates_history'] = mandates.ids[:100] + + values.update({ + 'mandates': mandates, + 'pager': pager, + }) + return request.render("partner_bank_account_portal.portal_my_mandates", values) + + def _get_mandate_domain(self): + return [] + + def _prepare_my_mandates_values(self, page, date_begin, date_end, domain=None, url="/my/mandates"): + values = self._prepare_portal_layout_values() + Mandate = request.env['account.banking.mandate'] + + domain = expression.AND([ + domain or [], + self._get_mandate_domain(), + ]) + + if date_begin and date_end: + domain += [('create_date', '>', date_begin), ('create_date', '<=', date_end)] + + values.update({ + 'date': date_begin, + # content according to pager and archive selected + # lambda function to get the invoices recordset when the pager will be defined in the main method of a route + 'mandates': lambda pager_offset: ( + Mandate.search(domain, limit=self._items_per_page, offset=pager_offset) + if Mandate.check_access_rights('read', raise_exception=False) else + Mandate + ), + 'page_name': 'mandates', + 'pager': { # vals to define the pager. + "url": url, + "url_args": {'date_begin': date_begin, 'date_end': date_end}, + "total": Mandate.search_count(domain) if Mandate.check_access_rights('read', raise_exception=False) else 0, + "page": page, + "step": self._items_per_page, + }, + 'default_url': url, + }) + return values diff --git a/partner_bank_account_portal/i18n/fr.po b/partner_bank_account_portal/i18n/fr.po new file mode 100644 index 0000000..e6eeb6f --- /dev/null +++ b/partner_bank_account_portal/i18n/fr.po @@ -0,0 +1,192 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_bank_account_portal +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2024-08-05 13:58+0000\n" +"PO-Revision-Date: 2024-08-05 13:58+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" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +msgid "1 registration" +msgstr "1 enregistrement" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandate +msgid " Data saved!" +msgstr "Données enregistrées!" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +msgid " Back to my bank accounts list" +msgstr " Retour à la liste des comptes bancaires" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandate +msgid " Back to my mandates list" +msgstr " Retour à la liste des mandats" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Associed IBAN" +msgstr "IBAN associé" + +#. module: partner_bank_account_portal +#: model:ir.model.fields,field_description:partner_bank_account_portal.field_account_setup_bank_manual_config__associated_mandate_count +#: model:ir.model.fields,field_description:partner_bank_account_portal.field_res_partner_bank__associated_mandate_count +msgid "Associated mandate count" +msgstr "Décompte de mandats associés au compte bancaire" + +#. module: partner_bank_account_portal +#: model:ir.model,name:partner_bank_account_portal.model_res_partner_bank +msgid "Bank Accounts" +msgstr "Comptes bancaires" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_home_bank_accounts +msgid "Bank accounts" +msgstr "Comptes bancaires" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Contact name" +msgstr "Nom du contact" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +msgid "Contact name:" +msgstr "Nom du contact : " + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Format" +msgstr "" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandate +msgid "Format :" +msgstr "" + +#. module: partner_bank_account_portal +#. odoo-python +#: code:addons/partner_bank_account_portal/controllers/portal_my_bank_accounts.py:0 +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +#, python-format +msgid "IBAN" +msgstr "" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +msgid "IBAN :" +msgstr "" + +#. module: partner_bank_account_portal +#. odoo-python +#: code:addons/partner_bank_account_portal/controllers/portal_my_bank_account.py:0 +#: code:addons/partner_bank_account_portal/controllers/portal_my_mandate.py:0 +#, python-format +msgid "Invalid Email! Please enter a valid email address." +msgstr "Email invalide ! Entrez une adresse email valide." + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Last debit date" +msgstr "Date du dernier débit" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_home_bank_accounts +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_home_menu_contract +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Mandates" +msgstr "Mandats" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +msgid "My bank account Details" +msgstr "Détails du compte bancaire" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandate +msgid "My mandate details" +msgstr "Details du mandat" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +msgid "Name of IBAN holder if different" +msgstr "Nom du titulaire de l'IBAN si différent :" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +msgid "Name of IBAN holder if different :" +msgstr "Nom du titulaire de l'IBAN si différent :" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +msgid "No registrations" +msgstr "Pas d'enregistrement" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +msgid "Number of associated mandates" +msgstr "Nombre de mandats associés" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Reference" +msgstr "Référence" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandate +msgid "Reference :" +msgstr "Référence :" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandate +msgid "Save" +msgstr "Enregistrer" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Signature date" +msgstr "Date de signature" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "Status" +msgstr "Statut" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +msgid "There are currently no bank accounts for your account." +msgstr "Aucun compte bancaire n'est accessible depuis votre compte." + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates +msgid "There are currently no mandates for your account." +msgstr "Aucun mandat n'est accessible depuis votre compte." + +#. module: partner_bank_account_portal +#. odoo-python +#: code:addons/partner_bank_account_portal/controllers/portal_my_bank_account.py:0 +#: code:addons/partner_bank_account_portal/controllers/portal_my_mandate.py:0 +#, python-format +msgid "This public name is already used, please find an other idea." +msgstr "Ce nom est déjà utilisé, veuillez trouver un autre nom." + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts +msgid "records" +msgstr "enregistrements" \ No newline at end of file diff --git a/partner_bank_account_portal/models/__init__.py b/partner_bank_account_portal/models/__init__.py new file mode 100644 index 0000000..d4a2902 --- /dev/null +++ b/partner_bank_account_portal/models/__init__.py @@ -0,0 +1,2 @@ + +from . import res_partner_bank \ No newline at end of file diff --git a/partner_bank_account_portal/models/res_partner_bank.py b/partner_bank_account_portal/models/res_partner_bank.py new file mode 100644 index 0000000..a6e3ba4 --- /dev/null +++ b/partner_bank_account_portal/models/res_partner_bank.py @@ -0,0 +1,17 @@ +# Copyright 2022 Elabore (https://elabore.coop) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + +class res_partner_bank(models.Model): + _inherit = "res.partner.bank" + + #count all mandate linked to the IBAN, even draft or canceled mandates + associated_mandate_count = fields.Integer("Associated mandate count", compute="_compute_associated_mandate_count") + + def _compute_associated_mandate_count(self): + for record in self: + count = self.env["account.banking.mandate"].search_count( + [("partner_bank_id", "=", record.id)] + ) + record.associated_mandate_count = count \ No newline at end of file diff --git a/partner_bank_account_portal/security/ir.model.access.csv b/partner_bank_account_portal/security/ir.model.access.csv new file mode 100644 index 0000000..252db76 --- /dev/null +++ b/partner_bank_account_portal/security/ir.model.access.csv @@ -0,0 +1,4 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +"access_res_partner_bank_group_portal","res_partner_bank group_portal","base.model_res_partner_bank","base.group_portal",1,0,0,0 +"access_res_bank_group_portal","res_bank group_portal","base.model_res_bank","base.group_portal",1,0,0,0 +"access_account_banking_mandate_group_portal","account_banking_mandate group_portal","account_banking_mandate.model_account_banking_mandate","base.group_portal",1,0,0,0 diff --git a/partner_bank_account_portal/security/members_security.xml b/partner_bank_account_portal/security/members_security.xml new file mode 100644 index 0000000..89d6008 --- /dev/null +++ b/partner_bank_account_portal/security/members_security.xml @@ -0,0 +1,34 @@ + + + + res_partner: portal: read access on my bank accounts + + [('partner_id', '=', user.partner_id.id)] + + + + + + + + + res_partner: portal: read access on my banks + + + + + + + + + + res_partner: portal: read access on my mandates + + [('partner_id', '=', user.partner_id.id)] + + + + + + + \ No newline at end of file diff --git a/partner_bank_account_portal/views/portal_my_bank_account_template.xml b/partner_bank_account_portal/views/portal_my_bank_account_template.xml new file mode 100644 index 0000000..6fed7f8 --- /dev/null +++ b/partner_bank_account_portal/views/portal_my_bank_account_template.xml @@ -0,0 +1,82 @@ + + + + \ No newline at end of file diff --git a/partner_bank_account_portal/views/portal_my_bank_accounts_template.xml b/partner_bank_account_portal/views/portal_my_bank_accounts_template.xml new file mode 100644 index 0000000..b06475e --- /dev/null +++ b/partner_bank_account_portal/views/portal_my_bank_accounts_template.xml @@ -0,0 +1,54 @@ + + + + \ No newline at end of file diff --git a/partner_bank_account_portal/views/portal_my_contract_template_inherit.xml b/partner_bank_account_portal/views/portal_my_contract_template_inherit.xml new file mode 100644 index 0000000..d67d730 --- /dev/null +++ b/partner_bank_account_portal/views/portal_my_contract_template_inherit.xml @@ -0,0 +1,18 @@ + + + + \ No newline at end of file diff --git a/partner_bank_account_portal/views/portal_my_home_template.xml b/partner_bank_account_portal/views/portal_my_home_template.xml new file mode 100644 index 0000000..cf3ec57 --- /dev/null +++ b/partner_bank_account_portal/views/portal_my_home_template.xml @@ -0,0 +1,41 @@ + + + + + + \ No newline at end of file diff --git a/partner_bank_account_portal/views/portal_my_mandate_template.xml b/partner_bank_account_portal/views/portal_my_mandate_template.xml new file mode 100644 index 0000000..4c486ef --- /dev/null +++ b/partner_bank_account_portal/views/portal_my_mandate_template.xml @@ -0,0 +1,60 @@ + + + + \ No newline at end of file diff --git a/partner_bank_account_portal/views/portal_my_mandates_template.xml b/partner_bank_account_portal/views/portal_my_mandates_template.xml new file mode 100644 index 0000000..91386b1 --- /dev/null +++ b/partner_bank_account_portal/views/portal_my_mandates_template.xml @@ -0,0 +1,57 @@ + + + + \ No newline at end of file -- 2.49.1 From 8b2c182103304b08b5869665139e7f980229cf59 Mon Sep 17 00:00:00 2001 From: Laetitia Da Costa Date: Thu, 26 Sep 2024 14:33:55 +0200 Subject: [PATCH 3/5] [ADD]16.0-bank_and_contract_portal:add rules for internal user using portal --- partner_bank_account_portal/__manifest__.py | 1 - .../controllers/portal_my_bank_account.py | 38 +------- .../controllers/portal_my_bank_accounts.py | 6 +- .../controllers/portal_my_mandate.py | 33 +------ .../controllers/portal_my_mandates.py | 8 +- partner_bank_account_portal/i18n/fr.po | 13 ++- .../security/members_security.xml | 96 +++++++++++++------ .../views/portal_my_bank_account_template.xml | 8 +- .../portal_my_bank_accounts_template.xml | 4 +- .../views/portal_my_mandate_template.xml | 60 ------------ .../views/portal_my_mandates_template.xml | 8 +- 11 files changed, 90 insertions(+), 185 deletions(-) delete mode 100644 partner_bank_account_portal/views/portal_my_mandate_template.xml diff --git a/partner_bank_account_portal/__manifest__.py b/partner_bank_account_portal/__manifest__.py index 847eede..16be39f 100644 --- a/partner_bank_account_portal/__manifest__.py +++ b/partner_bank_account_portal/__manifest__.py @@ -33,7 +33,6 @@ "views/portal_my_bank_accounts_template.xml", "views/portal_my_bank_account_template.xml", "views/portal_my_mandates_template.xml", - "views/portal_my_mandate_template.xml", "views/portal_my_contract_template_inherit.xml", ], # only loaded in demonstration mode diff --git a/partner_bank_account_portal/controllers/portal_my_bank_account.py b/partner_bank_account_portal/controllers/portal_my_bank_account.py index 8fe1132..f849704 100644 --- a/partner_bank_account_portal/controllers/portal_my_bank_account.py +++ b/partner_bank_account_portal/controllers/portal_my_bank_account.py @@ -1,6 +1,5 @@ -# Copyright 2020 Lokavaluto () +# Copyright 2024 Lokavaluto () # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). -import base64 from odoo import http, tools, _ from odoo.exceptions import AccessError, MissingError from odoo.http import request @@ -49,45 +48,10 @@ class CustomerPortalBankAccount(CustomerPortal): ] return fields - def _get_id_fields(self): - fields = [ - "bank_id", - ] - return fields - - def _get_main_boolean_bank_account_fields(self): - '''Provides the fields for which we must check the presence - in form's kw to know the value to save in the partner field. - All of them MUST start with "main_".''' - fields = [] - return fields - def _transform_res_partner_fields(self, kw, bank_account_fields, prefix=""): '''Transforms kw's values in res_partner fields and values''' return {key[len(prefix):]: kw[key] for key in bank_account_fields if key in kw} - def _cast_id_fields(self, kw, id_fields): - '''Cast ids fields in kw's values into a integer''' - result = {} - for key in id_fields: - if key in kw: - if kw[key] == '': - result[key] = None - elif not isinstance(kw[key], int): - result[key] = int(kw[key]) - else: - result[key] = kw[key] - return result - - def _add_boolean_values(self, values, kw, boolean_fields, prefix=""): - for key in boolean_fields: - values.update( - { - key[len(prefix):]: kw.get(key, "off") == "on", - } - ) - return values - def _get_page_saving_bank_account_values(self, kw): bank_account_fields = self._get_bank_account_fields() values = self._transform_res_partner_fields(kw, bank_account_fields) diff --git a/partner_bank_account_portal/controllers/portal_my_bank_accounts.py b/partner_bank_account_portal/controllers/portal_my_bank_accounts.py index 749156d..1ca30e3 100644 --- a/partner_bank_account_portal/controllers/portal_my_bank_accounts.py +++ b/partner_bank_account_portal/controllers/portal_my_bank_accounts.py @@ -14,7 +14,7 @@ class CustomerPortalBankAccounts(CustomerPortal): def _prepare_home_portal_values(self, counters): values = super()._prepare_home_portal_values(counters) if 'bank_account_count' in counters: - bank_account_count = request.env['res.partner.bank'].search_count([]) + bank_account_count = request.env['res.partner.bank'].search_count([('partner_id', '=', request.env.user.partner_id.id)]) values['bank_account_count'] = bank_account_count return values @@ -23,8 +23,6 @@ class CustomerPortalBankAccounts(CustomerPortal): res['acc_number'] = {'label': _('IBAN'), 'order': 'acc_number'} return res - - @http.route(['/my/bank_accounts', '/my/bank_accounts/page/'], type='http', auth="user", website=True) def portal_my_bank_accounts(self, page=1, date_begin=None, date_end=None, sortby=None, filterby=None, **kw): values = self._prepare_my_bank_accounts_values(page, date_begin, date_end, sortby, filterby) @@ -43,7 +41,7 @@ class CustomerPortalBankAccounts(CustomerPortal): return request.render("partner_bank_account_portal.portal_my_bank_accounts", values) def _get_bank_accounts_domain(self): - return [('active', '=', True)] + return [('active', '=', True),('partner_id', '=', request.env.user.partner_id.id)] def _prepare_my_bank_accounts_values(self, page, date_begin, date_end, sortby, filterby, domain=None, url="/my/bank_accounts"): diff --git a/partner_bank_account_portal/controllers/portal_my_mandate.py b/partner_bank_account_portal/controllers/portal_my_mandate.py index e3c306a..3864205 100644 --- a/partner_bank_account_portal/controllers/portal_my_mandate.py +++ b/partner_bank_account_portal/controllers/portal_my_mandate.py @@ -1,6 +1,5 @@ -# Copyright 2020 Lokavaluto () +# Copyright 2024 Lokavaluto () # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). -import base64 from odoo import http, tools, _ from odoo.exceptions import AccessError, MissingError from odoo.http import request @@ -51,31 +50,13 @@ class CustomerPortalMandate(CustomerPortal): ] return fields - def _get_main_boolean_mandate_fields(self): - '''Provides the fields for which we must check the presence - in form's kw to know the value to save in the partner field. - All of them MUST start with "main_".''' - fields = [] - return fields - def _transform_in_res_partner_fields(self, kw, mandate_fields, prefix=""): '''Transforms kw's values in res_partner fields and values''' return {key[len(prefix):]: kw[key] for key in mandate_fields if key in kw} - def _add_boolean_values(self, values, kw, boolean_fields, prefix=""): - for key in boolean_fields: - values.update( - { - key[len(prefix):]: kw.get(key, "off") == "on", - } - ) - return values - def _get_page_saving_mandate_values(self, kw): mandate_fields = self._get_mandate_fields() values = self._transform_in_res_partner_fields(kw, mandate_fields) - # boolean_fields = self._get_main_boolean_bank_account_fields() - # values = self._add_boolean_values(values, kw, boolean_fields) return values def _get_page_opening_values(self): @@ -95,12 +76,8 @@ class CustomerPortalMandate(CustomerPortal): def portal_my_mandate( self,mandate_id=None, access_token=None, redirect=None, **kw ): - # The following condition is to transform profile_id to an int, as it is sent as a string from the templace "portal_my_profile" - # TODO: find a better way to retrieve the profile_id at form submit step if not isinstance(mandate_id, int): mandate_id = int(mandate_id) - - # Check that the user has the right to see this profile try: mandate_sudo = self._document_check_access( "account.banking.mandate", mandate_id, access_token @@ -125,16 +102,8 @@ class CustomerPortalMandate(CustomerPortal): values.update({"error": error, "error_message": error_message}) values.update(kw) if not error: - # Update main profile new_values = self._get_page_saving_mandate_values(kw) mandate.sudo().write(new_values) - # Update public profile - # new_values = self._get_page_saving_public_structure_values(kw) - # public_profile.sudo().write(new_values) - # Update position profile - # new_values = self._get_page_saving_position_structure_values(kw) - # position_profile.sudo().write(new_values) - # End of updates if redirect: return request.redirect(redirect) return request.redirect("/my/mandates") diff --git a/partner_bank_account_portal/controllers/portal_my_mandates.py b/partner_bank_account_portal/controllers/portal_my_mandates.py index 97a85a1..361ad50 100644 --- a/partner_bank_account_portal/controllers/portal_my_mandates.py +++ b/partner_bank_account_portal/controllers/portal_my_mandates.py @@ -1,11 +1,9 @@ # -*- coding: utf-8 -*- # Part of Odoo. See LICENSE file for full copyright and licensing details. -from odoo import http, _ +from odoo import http from odoo.osv import expression from odoo.addons.portal.controllers.portal import CustomerPortal, pager as portal_pager -from odoo.exceptions import AccessError, MissingError -from collections import OrderedDict from odoo.http import request @@ -14,7 +12,7 @@ class CustomerPortalMandates(CustomerPortal): def _prepare_home_portal_values(self, counters): values = super()._prepare_home_portal_values(counters) if 'mandate_count' in counters: - mandate_count = request.env['account.banking.mandate'].search_count([]) + mandate_count = request.env['account.banking.mandate'].search_count([('partner_id', '=', request.env.user.partner_id.id)]) values['mandate_count'] = mandate_count return values @@ -36,7 +34,7 @@ class CustomerPortalMandates(CustomerPortal): return request.render("partner_bank_account_portal.portal_my_mandates", values) def _get_mandate_domain(self): - return [] + return [('partner_id', '=', request.env.user.partner_id.id)] def _prepare_my_mandates_values(self, page, date_begin, date_end, domain=None, url="/my/mandates"): values = self._prepare_portal_layout_values() diff --git a/partner_bank_account_portal/i18n/fr.po b/partner_bank_account_portal/i18n/fr.po index e6eeb6f..895ebb2 100644 --- a/partner_bank_account_portal/i18n/fr.po +++ b/partner_bank_account_portal/i18n/fr.po @@ -56,7 +56,7 @@ msgstr "Comptes bancaires" #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_home_bank_accounts msgid "Bank accounts" -msgstr "Comptes bancaires" +msgstr "IBAN" #. module: partner_bank_account_portal #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts @@ -110,7 +110,7 @@ msgstr "Date du dernier débit" #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_home_menu_contract #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_mandates msgid "Mandates" -msgstr "Mandats" +msgstr "Mandat de prélèvement SEPA" #. module: partner_bank_account_portal #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account @@ -125,7 +125,7 @@ msgstr "Details du mandat" #. module: partner_bank_account_portal #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts msgid "Name of IBAN holder if different" -msgstr "Nom du titulaire de l'IBAN si différent :" +msgstr "Nom du titulaire de l'IBAN si différent" #. module: partner_bank_account_portal #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account @@ -189,4 +189,9 @@ msgstr "Ce nom est déjà utilisé, veuillez trouver un autre nom." #. module: partner_bank_account_portal #: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_accounts msgid "records" -msgstr "enregistrements" \ No newline at end of file +msgstr "enregistrements" + +#. module: partner_bank_account_portal +#: model_terms:ir.ui.view,arch_db:partner_bank_account_portal.portal_my_bank_account +msgid "" +msgstr "" \ No newline at end of file diff --git a/partner_bank_account_portal/security/members_security.xml b/partner_bank_account_portal/security/members_security.xml index 89d6008..05e0832 100644 --- a/partner_bank_account_portal/security/members_security.xml +++ b/partner_bank_account_portal/security/members_security.xml @@ -1,34 +1,70 @@ - - res_partner: portal: read access on my bank accounts - - [('partner_id', '=', user.partner_id.id)] - - - - - - - - res_partner: portal: read access on my banks - - - - - - - + + + + + + res_partner: portal: read and write access on my bank accounts + + [('partner_id', '=', user.partner_id.id)] + + + + + + - - res_partner: portal: read access on my mandates - - [('partner_id', '=', user.partner_id.id)] - - - - - - - \ No newline at end of file + + res_partner: portal: read access on my banks + + + + + + + + + + res_partner: portal: read access on my mandates + + [('partner_id', '=', user.partner_id.id)] + + + + + + + + + + + + + + + res_partner: internal users: full access on my bank accounts + + [('partner_id', '=', user.partner_id.id)] + + + + + + + + + res_partner: account users and managers: full access on all bank accounts + + ['|', ('company_id', 'in', company_ids), ('company_id', '=', + False)] + + + + + + + + diff --git a/partner_bank_account_portal/views/portal_my_bank_account_template.xml b/partner_bank_account_portal/views/portal_my_bank_account_template.xml index 6fed7f8..36115bd 100644 --- a/partner_bank_account_portal/views/portal_my_bank_account_template.xml +++ b/partner_bank_account_portal/views/portal_my_bank_account_template.xml @@ -18,7 +18,7 @@
+ t-attf-class="form-group #{error.get('acc_number') and 'o_has_error' or ''}">
+ t-attf-class="form-group #{error.get('partner_id') and 'o_has_error' or ''}">
+ t-attf-class="form-group #{error.get('acc_holder_name') and 'o_has_error' or ''">
+ t-attf-class="form-group #{error.get('bank_id') and 'o_has_error' or ''}">