[tryton-debian-vcs] tryton-modules-authentication-sms branch debian created. 187ea6b438a49d3b749dc8f54eaec3ba0a66e141
Mathias Behrle
tryton-debian-vcs at alioth.debian.org
Mon Dec 12 09:39:03 UTC 2016
The following commit has been merged in the debian branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/tryton-modules-authentication-sms.git;a=commitdiff;h=187ea6b438a49d3b749dc8f54eaec3ba0a66e141
commit 187ea6b438a49d3b749dc8f54eaec3ba0a66e141
Author: Mathias Behrle <mathiasb at m9s.biz>
Date: Sat Dec 10 16:58:58 2016 +0100
Adding debian version 4.2.0-1.
diff --git a/CHANGELOG b/CHANGELOG
new file mode 100644
index 0000000..1c72ee3
--- /dev/null
+++ b/CHANGELOG
@@ -0,0 +1,2 @@
+Version 4.2.0 - 2016-11-28
+* Initial release
\ No newline at end of file
diff --git a/COPYRIGHT b/COPYRIGHT
new file mode 100644
index 0000000..5ccc52f
--- /dev/null
+++ b/COPYRIGHT
@@ -0,0 +1,15 @@
+Copyright (C) 2016 B2CK
+Copyright (C) 2016 Cédric Krier
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU 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 General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see <http://www.gnu.org/licenses/>.
diff --git a/INSTALL b/INSTALL
new file mode 100644
index 0000000..568f8d4
--- /dev/null
+++ b/INSTALL
@@ -0,0 +1,29 @@
+Installing trytond_authentication_sms
+=====================================
+
+Prerequisites
+-------------
+
+ * Python 2.7 or later (http://www.python.org/)
+ * trytond (http://www.tryton.org/)
+
+Installation
+------------
+
+Once you've downloaded and unpacked the trytond_authentication_sms source
+release, enter the directory where the archive was unpacked, and run:
+
+ python setup.py install
+
+Note that you may need administrator/root privileges for this step, as
+this command will by default attempt to install module to the Python
+site-packages directory on your system.
+
+For advanced options, please refer to the easy_install and/or the distutils
+documentation:
+
+ http://setuptools.readthedocs.io/en/latest/easy_install.html
+ http://docs.python.org/inst/inst.html
+
+To use without installation, extract the archive into ``trytond/modules`` with
+the directory name authentication_sms.
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..94a9ed0
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,674 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The GNU General Public License is a free, copyleft license for
+software and other kinds of works.
+
+ The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works. By contrast,
+the GNU General Public License is 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. We, the Free Software Foundation, use the
+GNU General Public License for most of our software; it applies also to
+any other work released this way by its authors. You can apply it to
+your programs, too.
+
+ 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.
+
+ To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights. Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received. You must make sure that they, too, receive
+or can get the source code. And you must show them these terms so they
+know their rights.
+
+ Developers that use the GNU GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+ For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this free software. For both users' and
+authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+ Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so. This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software. The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable. Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products. If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+ Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to a free program could
+make it effectively proprietary. To prevent this, the GPL assures that
+patents cannot be used to render the program non-free.
+
+ 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 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. Use with the GNU Affero General Public License.
+
+ 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 Affero 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 special requirements of the GNU Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+ 14. Revised Versions of this License.
+
+ The Free Software Foundation may publish revised and/or new versions of
+the GNU 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 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 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 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.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU 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 General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+Also add information on how to contact you by electronic and paper mail.
+
+ If the program does terminal interaction, make it output a short
+notice like this when it starts in an interactive mode:
+
+ <program> Copyright (C) <year> <name of author>
+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, your program's commands
+might be different; for a GUI interface, you would use an "about box".
+
+ 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 GPL, see
+<http://www.gnu.org/licenses/>.
+
+ The GNU General Public License does not permit incorporating your program
+into proprietary programs. If your program is a subroutine library, you
+may consider it more useful to permit linking proprietary applications with
+the library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License. But first, please read
+<http://www.gnu.org/philosophy/why-not-lgpl.html>.
diff --git a/MANIFEST.in b/MANIFEST.in
new file mode 100644
index 0000000..fb91042
--- /dev/null
+++ b/MANIFEST.in
@@ -0,0 +1,13 @@
+include INSTALL
+include README
+include COPYRIGHT
+include CHANGELOG
+include LICENSE
+include tryton.cfg
+include *.xml
+include view/*.xml
+include *.odt
+include locale/*.po
+include doc/*
+include icons/*
+include tests/*.rst
diff --git a/PKG-INFO b/PKG-INFO
new file mode 100644
index 0000000..05c5f69
--- /dev/null
+++ b/PKG-INFO
@@ -0,0 +1,76 @@
+Metadata-Version: 1.1
+Name: trytond_authentication_sms
+Version: 4.2.0
+Summary: Tryton module to authenticate users via SMS
+Home-page: http://www.tryton.org/
+Author: Tryton
+Author-email: issue_tracker at tryton.org
+License: GPL-3
+Download-URL: http://downloads.tryton.org/4.2/
+Description: trytond_authentication_sms
+ ==========================
+
+ The authentication_sms module of the Tryton application platform.
+
+ Installing
+ ----------
+
+ See INSTALL
+
+ Support
+ -------
+
+ If you encounter any problems with Tryton, please don't hesitate to ask
+ questions on the Tryton bug tracker, mailing list, wiki or IRC channel:
+
+ http://bugs.tryton.org/
+ http://groups.tryton.org/
+ http://wiki.tryton.org/
+ irc://irc.freenode.net/tryton
+
+ License
+ -------
+
+ See LICENSE
+
+ Copyright
+ ---------
+
+ See COPYRIGHT
+
+
+ For more information please visit the Tryton web site:
+
+ http://www.tryton.org/
+
+Keywords: tryton sms authentication two-factor 2FA
+Platform: UNKNOWN
+Classifier: Development Status :: 5 - Production/Stable
+Classifier: Environment :: Plugins
+Classifier: Framework :: Tryton
+Classifier: Intended Audience :: Developers
+Classifier: Intended Audience :: Financial and Insurance Industry
+Classifier: Intended Audience :: Legal Industry
+Classifier: License :: OSI Approved :: GNU General Public License (GPL)
+Classifier: Natural Language :: Bulgarian
+Classifier: Natural Language :: Catalan
+Classifier: Natural Language :: Czech
+Classifier: Natural Language :: Dutch
+Classifier: Natural Language :: English
+Classifier: Natural Language :: French
+Classifier: Natural Language :: German
+Classifier: Natural Language :: Hungarian
+Classifier: Natural Language :: Italian
+Classifier: Natural Language :: Polish
+Classifier: Natural Language :: Portuguese (Brazilian)
+Classifier: Natural Language :: Russian
+Classifier: Natural Language :: Slovenian
+Classifier: Natural Language :: Spanish
+Classifier: Operating System :: OS Independent
+Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: 3.3
+Classifier: Programming Language :: Python :: 3.4
+Classifier: Programming Language :: Python :: 3.5
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
+Classifier: Topic :: Office/Business
diff --git a/README b/README
new file mode 100644
index 0000000..a6bbe45
--- /dev/null
+++ b/README
@@ -0,0 +1,35 @@
+trytond_authentication_sms
+==========================
+
+The authentication_sms module of the Tryton application platform.
+
+Installing
+----------
+
+See INSTALL
+
+Support
+-------
+
+If you encounter any problems with Tryton, please don't hesitate to ask
+questions on the Tryton bug tracker, mailing list, wiki or IRC channel:
+
+ http://bugs.tryton.org/
+ http://groups.tryton.org/
+ http://wiki.tryton.org/
+ irc://irc.freenode.net/tryton
+
+License
+-------
+
+See LICENSE
+
+Copyright
+---------
+
+See COPYRIGHT
+
+
+For more information please visit the Tryton web site:
+
+ http://www.tryton.org/
diff --git a/__init__.py b/__init__.py
new file mode 100644
index 0000000..704bd23
--- /dev/null
+++ b/__init__.py
@@ -0,0 +1,12 @@
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+
+from trytond.pool import Pool
+from .res import *
+
+
+def register():
+ Pool.register(
+ User,
+ SMSCode,
+ module='authentication_sms', type_='model')
diff --git a/debian/changelog b/debian/changelog
new file mode 100644
index 0000000..bbbff02
--- /dev/null
+++ b/debian/changelog
@@ -0,0 +1,5 @@
+tryton-modules-authentication-sms (4.2.0-1) unstable; urgency=medium
+
+ * Initial commit (Closes: #847182).
+
+ -- Mathias Behrle <mathiasb at m9s.biz> Sun, 11 Dec 2016 10:18:31 +0100
diff --git a/debian/compat b/debian/compat
new file mode 100644
index 0000000..ec63514
--- /dev/null
+++ b/debian/compat
@@ -0,0 +1 @@
+9
diff --git a/debian/control b/debian/control
new file mode 100644
index 0000000..c6fe48f
--- /dev/null
+++ b/debian/control
@@ -0,0 +1,41 @@
+Source: tryton-modules-authentication-sms
+Section: python
+Priority: optional
+Maintainer: Debian Tryton Maintainers <maintainers at debian.tryton.org>
+Uploaders: Mathias Behrle <mathiasb at m9s.biz>
+Build-Depends:
+ debhelper (>= 9),
+ dh-python,
+ python,
+ python-setuptools,
+Standards-Version: 3.9.8
+Homepage: http://www.tryton.org/
+Vcs-Browser: https://anonscm.debian.org/cgit/tryton/tryton-modules-authentication-sms.git
+Vcs-Git: https://anonscm.debian.org/cgit/tryton/tryton-modules-authentication-sms.git
+X-Python-Version: >= 2.7
+
+Package: tryton-modules-authentication-sms
+Architecture: all
+Depends:
+ python-pkg-resources,
+ tryton-server (>= ${version:major}),
+ ${misc:Depends},
+ ${python:Depends},
+Description: Tryton Application Platform (Authentication SMS Module)
+ Tryton is a high-level general purpose application platform. It is the base
+ of a complete business solution as well as a comprehensive health and hospital
+ information system (GNUHealth).
+ .
+ This module allows one to authenticate users via SMS. There are two
+ authentication methods which can be used in the authentications list of the
+ session section in the configuration:
+ .
+ The sms method just sends a code via SMS to the user. This code can directly
+ be used in the login dialog.
+ .
+ The password_sms method sends a code only after the user entered a valid
+ password providing a two-factor authentication method
+ (https://en.wikipedia.org/wiki/Two-factor_authentication).
+ .
+ Both methods require that the user has a *mobile* phone number defined
+ otherwise he can not be authenticated with those methods.
diff --git a/debian/copyright b/debian/copyright
new file mode 100644
index 0000000..d123e4b
--- /dev/null
+++ b/debian/copyright
@@ -0,0 +1,27 @@
+Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
+
+Files: *
+Copyright: 2016 B2CK
+ 2016 Cédric Krier
+License: GPL-3+
+
+Files: debian/*
+Copyright: 2016 Mathias Behrle <mbehrle at debian.org>
+License: GPL-3+
+
+License: GPL-3+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU 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 General Public License for more details.
+ .
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+ .
+ The complete text of the GNU General Public License
+ can be found in /usr/share/common-licenses/GPL-3 file.
diff --git a/debian/docs b/debian/docs
new file mode 100644
index 0000000..a2e6bd4
--- /dev/null
+++ b/debian/docs
@@ -0,0 +1 @@
+doc/
diff --git a/debian/gbp.conf b/debian/gbp.conf
new file mode 100644
index 0000000..fd37acc
--- /dev/null
+++ b/debian/gbp.conf
@@ -0,0 +1,15 @@
+# Settings for Debian Tryton Maintainer repositories
+# for usage with git-buildpackage
+
+[DEFAULT]
+debian-branch = debian
+pristine-tar = True
+
+[buildpackage]
+ignore-new = True
+# Use with orig.tar.xz tarballs, used for releases 2.2 to 3.0
+# Currently we are using upstream compression, which is gz
+#compression = xz
+# Use export-dir at your discretion to avoid git-buildpackage messing
+# your git repeository
+#export-dir = ../build-area/
diff --git a/debian/rules b/debian/rules
new file mode 100755
index 0000000..020614c
--- /dev/null
+++ b/debian/rules
@@ -0,0 +1,17 @@
+#!/usr/bin/make -f
+
+MAJOR := $(shell python setup.py --version | awk -F "." '{print $$1 "." $$2}')
+
+# Don't run tests for Tryton modules, they possibly depend on other modules
+# of the same version, that are not yet available at build time from the archive
+# in case of new releases.
+# For the complete test suites refer to http://tests.tryton.org/
+export PYBUILD_DISABLE=test
+
+%:
+ dh $@ --with python2 --buildsystem=pybuild
+
+override_dh_gencontrol:
+ dh_gencontrol -- -Vversion:major="$(MAJOR)"
+
+
diff --git a/debian/source/format b/debian/source/format
new file mode 100644
index 0000000..163aaf8
--- /dev/null
+++ b/debian/source/format
@@ -0,0 +1 @@
+3.0 (quilt)
diff --git a/debian/upstream/signing-key.asc b/debian/upstream/signing-key.asc
new file mode 100644
index 0000000..962b82d
--- /dev/null
+++ b/debian/upstream/signing-key.asc
@@ -0,0 +1,460 @@
+-----BEGIN PGP PUBLIC KEY BLOCK-----
+Version: GnuPG v1
+
+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
+pvm+lnoNgb6Jq88/p0GZrfi3Jjlm+MN1+oIeLNrJ6So7QZKphSXhdJYpk3EUhPGT
+pyzIZemNODPRKameaSxmcvEWJpVPs0G0pC0Z2yqTnYQzUXVLSfYrRrFYEmvuNrQl
+Q8OpZHJpYyBLcmllciA8Y2VkcmljLmtyaWVyQGIyY2suY29tPokCNwQTAQgAIQUC
+SgVk3wIbAwULCQgHAwUVCgkICwUWAgMBAAIeAQIXgAAKCRA8rT/USZVWA014D/4w
+lB4weKktE18HrNgcqKPOx0vDSnFSftY05H1vePAnw9TbCi6KoQepjcod8Bt0WbTs
+p6L4m4eAywNNXnkcmAQ40Tc2ZckIrL8oYstbHaK/klAVib0Q+6ffg9reYYGtbikl
+r04RtY4LyqiiGgCACvvfjxKRtjrpsx6DPcb1MqQwoT6PLd/fu4+UQOXJOmcYpMah
+qZMMS0zyN9balAs5M/WOGDMD998WmGxs+kZ7SUuSTkeW95WrwgFpBgrSbyITc8NP
+qmsoZcZgcogPYrEw6bgq2bZ/DpmCW/M5nDb4n7oMQZ5NwF+BeIp6Uuh+asWFe/PW
+TGoJ7f4l3T4po2iJPszK5hvU9/r7WjddlCCWi8zpzspsSzOqF0y8Ne7Mp2sHpWEH
+x739VFvxySwtkv08YWjF1buiMo4Tswu2WbbCX4vt2LH1RXp/oleRlWlgMkpQSq+/
+AL7HFzWWurY6hf4WJQ3XKRYtaZIuqD6VcfdK167tZq6nDRnXAcZsDITeK8/yuOXo
+VkV3OHXU5M7wadySJLhfunZN3/K4pgEmv/mEJA+O1xuoiFI4qENaYBWuDTs2y5UD
+rxs3UX6Vz4Rqt2VkyqHdv9hDaVP+IErGUPqNmHUFuV1liTXIgFIE1Z7MQH67umRy
+pgK61jkzdgj7BrdrdxmhiE20SBX5xfm1lIBeoAsMsohGBBARCAAGBQJKBWauAAoJ
+EF1CVh5OpP8xoicAniJt+u9nZiJKK1SGrTPzqodGMhEVAKCbT5aPwgYB0rKxlENb
+k7gjPeHWs4hGBBARAgAGBQJOXMwnAAoJENXyeXM9f/tlE1IAoJaSz/2d81JSr78R
+AkzP8UNS+X4xAJ9xWTZkEV1ba9xqBeuOTXl3dvCxbYkCNwQTAQgAIQIbAwULCQgH
+AwUVCgkICwUWAgMBAAIeAQIXgAUCUnUdiAAKCRA8rT/USZVWA+H/D/9y74s8iyxZ
+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
+=vhyP
+-----END PGP PUBLIC KEY BLOCK-----
+-----BEGIN PGP PUBLIC KEY BLOCK-----
+
+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
+9A==
+=urY5
+-----END PGP PUBLIC KEY BLOCK-----
diff --git a/debian/watch b/debian/watch
new file mode 100644
index 0000000..8ed16cf
--- /dev/null
+++ b/debian/watch
@@ -0,0 +1,2 @@
+version=3
+opts=pgpsigurlmangle=s/$/.asc/ http://downloads.tryton.org/current/ .*trytond_authentication_sms-(\d.*)\.(?:tgz|tbz2|txz|tar\.(?:gz|bz2|xz))
diff --git a/doc/index.rst b/doc/index.rst
new file mode 100644
index 0000000..c62ed47
--- /dev/null
+++ b/doc/index.rst
@@ -0,0 +1,52 @@
+Authentication SMS Module
+#########################
+
+The `SMS <https://en.wikipedia.org/wiki/Short_Message_Service>`_ authentication
+module allows to authenticate users via SMS. There are two authentication
+methods `sms` and `password_sms` which can be used in the `authentications`
+list of the `session` section in the configuration.
+
+The `sms` method just send a code via SMS to the user. Then the user needs to
+transcribe the code into the login dialog.
+
+The `password_sms` method send a code only after the user entered a valid
+password. This provides a `two-factor authentication
+<https://en.wikipedia.org/wiki/Two-factor_authentication>`_ method.
+
+Both methods require that the user has a *Mobile* phone number defined
+otherwise he can not be authenticated with those methods.
+
+Configuration
+*************
+
+The configuration of the module is set in the `authentication_sms` section.
+
+function
+--------
+
+The fully qualified name of the method to send SMS. It must take three
+arguments: text, to and from.
+This method is required to send SMS.
+
+from
+----
+
+The number from which the SMS are sent.
+
+length
+------
+
+The length of the generated code.
+Default: 6
+
+ttl
+---
+
+The time to live for the generated codes in seconds.
+Default: 300
+
+name
+----
+
+The name used in the SMS text.
+Default: Tryton
diff --git a/locale/bg.po b/locale/bg.po
new file mode 100644
index 0000000..176dd7a
--- /dev/null
+++ b/locale/bg.po
@@ -0,0 +1,68 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Мобилен"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Код"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Създадено на"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Създадено от"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Условие за плащане"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Потребител"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Променено на"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Променено от"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/ca.po b/locale/ca.po
new file mode 100644
index 0000000..1283adc
--- /dev/null
+++ b/locale/ca.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr "%(name)s codi %(code)s"
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr "Número mòbil incorrecte."
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Mòbil"
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Codi"
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Data de creació"
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Usuari de creació"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Nom"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Usuari"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Data de modificació"
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Usuari de modificació"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr "Número de telèfon que suporta rebre SMS."
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr "Codi SMS"
diff --git a/locale/cs.po b/locale/cs.po
new file mode 100644
index 0000000..fdb3065
--- /dev/null
+++ b/locale/cs.po
@@ -0,0 +1,60 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Namu"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr ""
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/de.po b/locale/de.po
new file mode 100644
index 0000000..bfb6b0e
--- /dev/null
+++ b/locale/de.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr "%(name)s Code %(code)s"
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr "Falsche Mobilnummer."
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Mobiltelefon"
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Code"
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Erstellungsdatum"
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Erstellt durch"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Name"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Benutzer"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "Benutzer ID"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Zuletzt geändert"
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Letzte Änderung durch"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr "Eine Telefonnummer, die den Empfang von SMS unterstützt"
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr "SMS Code"
diff --git a/locale/es.po b/locale/es.po
new file mode 100644
index 0000000..3a7bef2
--- /dev/null
+++ b/locale/es.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr "%(name)s código %(code)s"
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr "Número móvil incorrecto."
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Móvil"
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Código"
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Fecha de creación"
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Usuario de creación"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Nombre"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Usuario"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "ID usuario"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Fecha de modificación"
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Usuario de modificación"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr "Número de teléfono que puede recibir SMS"
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr "Código SMS"
diff --git a/locale/es_419.po b/locale/es_419.po
new file mode 100644
index 0000000..957b4e2
--- /dev/null
+++ b/locale/es_419.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Creado por usuario"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "ID de usuario"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Modificado por usuario"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/fr.po b/locale/fr.po
new file mode 100644
index 0000000..4b783e5
--- /dev/null
+++ b/locale/fr.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr "%(name)s code %(code)s"
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr "Mauvais mobile."
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Mobile"
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Code"
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Date de création"
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Créé par"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Nom"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Utilisateur"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "ID d'utilisateur"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Date de mise à jour"
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Mis à jour par"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr "Numéro de téléphone qui support la réception de SMS"
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr "Code SMS"
diff --git a/locale/hu_HU.po b/locale/hu_HU.po
new file mode 100644
index 0000000..4881b88
--- /dev/null
+++ b/locale/hu_HU.po
@@ -0,0 +1,68 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Mobiltelefon"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Partner kód"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Létrehozás détuma"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Által létrehozva "
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Név"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Felhasználó"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "utolsó módosítás dátuma"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Által módosítva"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/it_IT.po b/locale/it_IT.po
new file mode 100644
index 0000000..7c0db7a
--- /dev/null
+++ b/locale/it_IT.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr "%(name)s codice %(code)s"
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr "telefono errato"
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Cellulare"
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Codice"
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "creato il"
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "creato da"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Nome"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Utente"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "ID utente:"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "modificato il"
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "modificato da"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr "numero telefonico abilitato alla ricezione SMS"
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr "codice SMS"
diff --git a/locale/ja_JP.po b/locale/ja_JP.po
new file mode 100644
index 0000000..0900d08
--- /dev/null
+++ b/locale/ja_JP.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr ""
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/lo.po b/locale/lo.po
new file mode 100644
index 0000000..86e1c5b
--- /dev/null
+++ b/locale/lo.po
@@ -0,0 +1,68 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "ໂທລະສັບມືຖື"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "ລະຫັດແຂວງ"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "ສ້າງວັນທີ"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "ສ້າງຜູ້ໃຊ້ງານ"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ເລດລຳດັບ"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "ຊື່"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "ຜູ້ໃຊ້"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "ວັນທີບັນທຶກ"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "ສ້າງຜູ້ໃຊ້"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/lt.po b/locale/lt.po
new file mode 100644
index 0000000..fdb3065
--- /dev/null
+++ b/locale/lt.po
@@ -0,0 +1,60 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Namu"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr ""
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr ""
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/nl.po b/locale/nl.po
new file mode 100644
index 0000000..112b66c
--- /dev/null
+++ b/locale/nl.po
@@ -0,0 +1,68 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Mobiel"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Code"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Datum"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Gebruiker"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Naam bijlage"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Gebruiker"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Schrijfdatum"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Gebruiker"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/pl.po b/locale/pl.po
new file mode 100644
index 0000000..636f322
--- /dev/null
+++ b/locale/pl.po
@@ -0,0 +1,59 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr "%(name)s kod %(code)s"
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr "Nieprawidłowa komórka."
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Komórka"
+
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Kod"
+
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Data utworzenia"
+
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Utworzył"
+
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Nazwa"
+
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Użytkownik"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr "ID użytkownika"
+
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Data zapisu"
+
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Zapisał"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr "Numer telefonu, który umożliwia otrzymywanie SMS-ów"
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr "Kod SMS"
diff --git a/locale/pt_BR.po b/locale/pt_BR.po
new file mode 100644
index 0000000..ac54491
--- /dev/null
+++ b/locale/pt_BR.po
@@ -0,0 +1,68 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Celular"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Código"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Data de criação"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Usuário de Criação"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Nome"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Usuário"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Editado por"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Gravado por"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/ru.po b/locale/ru.po
new file mode 100644
index 0000000..7b38307
--- /dev/null
+++ b/locale/ru.po
@@ -0,0 +1,68 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "сот.телефон"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Код языка"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Дата создания"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Создано пользователем"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Правило оплаты"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Пользователь"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Дата изменения"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Изменено пользователем"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/sl.po b/locale/sl.po
new file mode 100644
index 0000000..e10c6c2
--- /dev/null
+++ b/locale/sl.po
@@ -0,0 +1,67 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr "Mobilni"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "Šifra"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "Izdelano"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "Izdelal"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "ID"
+
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "Ime"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "Uporabnik"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "Zapisano"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "Zapisal"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/locale/zh_CN.po b/locale/zh_CN.po
new file mode 100644
index 0000000..1db32b1
--- /dev/null
+++ b/locale/zh_CN.po
@@ -0,0 +1,67 @@
+#
+msgid ""
+msgstr "Content-Type: text/plain; charset=utf-8\n"
+
+msgctxt "error:res.user.login.sms_code:"
+msgid "%(name)s code %(code)s"
+msgstr ""
+
+msgctxt "error:res.user:"
+msgid "Wrong mobile."
+msgstr ""
+
+msgctxt "field:res.user,mobile:"
+msgid "Mobile"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,code:"
+msgid "Code"
+msgstr "语言编码"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_date:"
+msgid "Create Date"
+msgstr "创建日期:"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,create_uid:"
+msgid "Create User"
+msgstr "添加用户"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,id:"
+msgid "ID"
+msgstr "编号"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,rec_name:"
+msgid "Name"
+msgstr "纳木"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,user:"
+msgid "User"
+msgstr "用户"
+
+msgctxt "field:res.user.login.sms_code,user_id:"
+msgid "User ID"
+msgstr ""
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_date:"
+msgid "Write Date"
+msgstr "写入日期"
+
+#, fuzzy
+msgctxt "field:res.user.login.sms_code,write_uid:"
+msgid "Write User"
+msgstr "写入帐号"
+
+msgctxt "help:res.user,mobile:"
+msgid "Phone number that supports receiving SMS"
+msgstr ""
+
+msgctxt "model:res.user.login.sms_code,name:"
+msgid "SMS Code"
+msgstr ""
diff --git a/res.py b/res.py
new file mode 100644
index 0000000..51d096b
--- /dev/null
+++ b/res.py
@@ -0,0 +1,150 @@
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+import datetime
+import importlib
+import logging
+import random
+
+from trytond.config import config
+from trytond.exceptions import LoginException
+from trytond.model import ModelSQL, fields
+from trytond.pool import PoolMeta, Pool
+from trytond.transaction import Transaction
+from trytond.tools import resolve
+
+__all__ = ['User', 'SMSCode']
+logger = logging.getLogger(__name__)
+
+
+def send_sms(text, to):
+ assert len(text) <= 160, text
+ if config.has_option('authentication_sms', 'function'):
+ func = resolve(config.get('authentication_sms', 'function'))
+ if func:
+ from_ = config.get('authentication_sms', 'from', default=None)
+ return func(text, to, from_)
+ logger.error('Could not send SMS to %s: "%s"', to, text)
+
+
+class User:
+ __metaclass__ = PoolMeta
+ __name__ = 'res.user'
+ mobile = fields.Char('Mobile',
+ help='Phone number that supports receiving SMS')
+
+ @classmethod
+ def __setup__(cls):
+ super(User, cls).__setup__()
+ cls._preferences_fields.append('mobile')
+ cls._error_messages.update({
+ 'wrong_mobile': 'Wrong mobile.',
+ })
+
+ @classmethod
+ def set_preferences(cls, values, parameters):
+ super(User, cls).set_preferences(values, parameters)
+ user_id = Transaction().user
+ user = cls(user_id)
+ # Check new mobile
+ if 'mobile' in values:
+ # Use a new transaction to store the SMS code
+ with Transaction().new_transaction() as transaction:
+ # Force sending code to new mobile
+ SMSCode.send(user_id, mobile=values['mobile'])
+ try:
+ user_id = cls._login_sms(user.login, parameters)
+ except LoginException:
+ transaction.commit()
+ raise
+ if not user_id:
+ cls.raise_user_error('wrong_mobile')
+
+ @classmethod
+ def _login_sms(cls, login, parameters):
+ pool = Pool()
+ SMSCode = pool.get('res.user.login.sms_code')
+ user_id, _ = cls._get_login(login)
+ if user_id:
+ SMSCode.send(user_id)
+ if 'sms_code' in parameters:
+ code = parameters['sms_code']
+ if not code:
+ return
+ if SMSCode.check(user_id, code):
+ return user_id
+ msg = SMSCode.fields_get(['code'])['code']['string']
+ raise LoginException('sms_code', msg, type='char')
+
+ @classmethod
+ def _login_password_sms(cls, login, parameters):
+ user_id = cls._login_password(login, parameters)
+ if user_id:
+ return cls._login_sms(login, parameters)
+
+
+class SMSCode(ModelSQL):
+ """SMS Code
+
+ This class is separated from the res.user one in order to prevent locking
+ the res.user table when in a long running process.
+ """
+ __name__ = 'res.user.login.sms_code'
+
+ user_id = fields.Integer('User ID', select=True)
+ user = fields.Function(fields.Many2One('res.user', 'User'), 'get_user')
+ code = fields.Char('Code')
+
+ @classmethod
+ def __setup__(cls):
+ super(SMSCode, cls).__setup__()
+ cls._error_messages.update({
+ 'sms_text': '%(name)s code %(code)s',
+ })
+
+ @classmethod
+ def default_code(cls):
+ length = config.getint('authentication_sms', 'length', default=6)
+ srandom = random.SystemRandom()
+ return ''.join(str(srandom.randint(0, 9)) for _ in range(length))
+
+ def get_user(self, name):
+ return self.user_id
+
+ @classmethod
+ def get(cls, user, _now=None):
+ if _now is None:
+ _now = datetime.datetime.now()
+ timeout = datetime.timedelta(
+ seconds=config.getint('authentication_sms', 'ttl', default=5 * 60))
+ records = cls.search([
+ ('user_id', '=', user),
+ ])
+ for record in records:
+ if abs(record.create_date - _now) < timeout:
+ yield record
+ else:
+ cls.delete([record])
+
+ @classmethod
+ def send(cls, user, mobile=None):
+ if not list(cls.get(user)) or mobile:
+ record = cls(user_id=user)
+ record.save()
+ name = config.get('authentication_sms', 'name', default='Tryton')
+ text = cls.raise_user_error(
+ 'sms_text', {
+ 'name': name,
+ 'code': record.code,
+ }, raise_exception=False)
+ if mobile:
+ send_sms(text, mobile)
+ elif record.user.mobile:
+ send_sms(text, record.user.mobile)
+
+ @classmethod
+ def check(cls, user, code):
+ for record in cls.get(user):
+ if record.code == code:
+ cls.delete([record])
+ return True
+ return False
diff --git a/res.xml b/res.xml
new file mode 100644
index 0000000..023ee94
--- /dev/null
+++ b/res.xml
@@ -0,0 +1,16 @@
+<?xml version="1.0"?>
+<tryton>
+ <data>
+ <record model="ir.ui.view" id="user_view_form">
+ <field name="model">res.user</field>
+ <field name="inherit" ref="res.user_view_form"/>
+ <field name="name">user_form</field>
+ </record>
+
+ <record model="ir.ui.view" id="user_view_form_preferences">
+ <field name="model">res.user</field>
+ <field name="inherit" ref="res.user_view_form_preferences"/>
+ <field name="name">user_form_preferences</field>
+ </record>
+ </data>
+</tryton>
diff --git a/setup.cfg b/setup.cfg
new file mode 100644
index 0000000..861a9f5
--- /dev/null
+++ b/setup.cfg
@@ -0,0 +1,5 @@
+[egg_info]
+tag_build =
+tag_date = 0
+tag_svn_revision = 0
+
diff --git a/setup.py b/setup.py
new file mode 100644
index 0000000..8b44c41
--- /dev/null
+++ b/setup.py
@@ -0,0 +1,124 @@
+#!/usr/bin/env python
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+
+from setuptools import setup
+import re
+import os
+import io
+try:
+ from configparser import ConfigParser
+except ImportError:
+ from ConfigParser import ConfigParser
+
+
+def read(fname):
+ return io.open(
+ os.path.join(os.path.dirname(__file__), fname),
+ 'r', encoding='utf-8').read()
+
+
+def get_require_version(name):
+ if minor_version % 2:
+ require = '%s >= %s.%s.dev0, < %s.%s'
+ else:
+ require = '%s >= %s.%s, < %s.%s'
+ require %= (name, major_version, minor_version,
+ major_version, minor_version + 1)
+ return require
+
+config = ConfigParser()
+config.readfp(open('tryton.cfg'))
+info = dict(config.items('tryton'))
+for key in ('depends', 'extras_depend', 'xml'):
+ if key in info:
+ info[key] = info[key].strip().splitlines()
+version = info.get('version', '0.0.1')
+major_version, minor_version, _ = version.split('.', 2)
+major_version = int(major_version)
+minor_version = int(minor_version)
+name = 'trytond_authentication_sms'
+
+download_url = 'http://downloads.tryton.org/%s.%s/' % (
+ major_version, minor_version)
+if minor_version % 2:
+ version = '%s.%s.dev0' % (major_version, minor_version)
+ download_url = (
+ 'hg+http://hg.tryton.org/modules/%s#egg=%s-%s' % (
+ name[8:], name, version))
+
+requires = []
+for dep in info.get('depends', []):
+ if not re.match(r'(ir|res)(\W|$)', dep):
+ requires.append(get_require_version('trytond_%s' % dep))
+requires.append(get_require_version('trytond'))
+
+tests_require = []
+dependency_links = []
+if minor_version % 2:
+ # Add development index for testing with proteus
+ dependency_links.append('https://trydevpi.tryton.org/')
+
+setup(name=name,
+ version=version,
+ description='Tryton module to authenticate users via SMS',
+ long_description=read('README'),
+ author='Tryton',
+ author_email='issue_tracker at tryton.org',
+ url='http://www.tryton.org/',
+ download_url=download_url,
+ keywords='tryton sms authentication two-factor 2FA',
+ package_dir={'trytond.modules.authentication_sms': '.'},
+ packages=[
+ 'trytond.modules.authentication_sms',
+ 'trytond.modules.authentication_sms.tests',
+ ],
+ package_data={
+ 'trytond.modules.authentication_sms': (info.get('xml', [])
+ + ['tryton.cfg', 'view/*.xml', 'locale/*.po', '*.odt',
+ 'icons/*.svg', 'tests/*.rst']),
+ },
+ classifiers=[
+ 'Development Status :: 5 - Production/Stable',
+ 'Environment :: Plugins',
+ 'Framework :: Tryton',
+ 'Intended Audience :: Developers',
+ 'Intended Audience :: Financial and Insurance Industry',
+ 'Intended Audience :: Legal Industry',
+ 'License :: OSI Approved :: GNU General Public License (GPL)',
+ 'Natural Language :: Bulgarian',
+ 'Natural Language :: Catalan',
+ 'Natural Language :: Czech',
+ 'Natural Language :: Dutch',
+ 'Natural Language :: English',
+ 'Natural Language :: French',
+ 'Natural Language :: German',
+ 'Natural Language :: Hungarian',
+ 'Natural Language :: Italian',
+ 'Natural Language :: Polish',
+ 'Natural Language :: Portuguese (Brazilian)',
+ 'Natural Language :: Russian',
+ 'Natural Language :: Slovenian',
+ 'Natural Language :: Spanish',
+ 'Operating System :: OS Independent',
+ 'Programming Language :: Python :: 2.7',
+ 'Programming Language :: Python :: 3.3',
+ 'Programming Language :: Python :: 3.4',
+ 'Programming Language :: Python :: 3.5',
+ 'Programming Language :: Python :: Implementation :: CPython',
+ 'Programming Language :: Python :: Implementation :: PyPy',
+ 'Topic :: Office/Business',
+ ],
+ license='GPL-3',
+ install_requires=requires,
+ dependency_links=dependency_links,
+ zip_safe=False,
+ entry_points="""
+ [trytond.modules]
+ authentication_sms = trytond.modules.authentication_sms
+ """,
+ test_suite='tests',
+ test_loader='trytond.test_loader:Loader',
+ tests_require=tests_require,
+ use_2to3=True,
+ )
diff --git a/tests/__init__.py b/tests/__init__.py
new file mode 100644
index 0000000..cf1af13
--- /dev/null
+++ b/tests/__init__.py
@@ -0,0 +1,9 @@
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+
+try:
+ from trytond.modules.authentication_sms.tests.test_authentication_sms import suite, send_sms
+except ImportError:
+ from .test_authentication_sms import suite, send_sms
+
+__all__ = ['suite', 'send_sms']
diff --git a/tests/test_authentication_sms.py b/tests/test_authentication_sms.py
new file mode 100644
index 0000000..5270762
--- /dev/null
+++ b/tests/test_authentication_sms.py
@@ -0,0 +1,130 @@
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+import datetime
+import unittest
+
+from trytond.tests.test_tryton import ModuleTestCase, with_transaction
+from trytond.tests.test_tryton import suite as test_suite
+from trytond.config import config
+from trytond.pool import Pool
+from trytond.exceptions import LoginException
+
+
+def send_sms(text, to, from_):
+ sms_queue.append({
+ 'text': text,
+ 'to': to,
+ 'from': from_,
+ })
+sms_queue = []
+
+
+class AuthenticationSMSTestCase(ModuleTestCase):
+ 'Test Authentication SMS module'
+ module = 'authentication_sms'
+
+ def setUp(self):
+ super(AuthenticationSMSTestCase, self).setUp()
+ methods = config.get('session', 'authentications')
+ config.set('session', 'authentications', 'password_sms')
+ self.addCleanup(config.set, 'session', 'authentications', methods)
+ config.add_section('authentication_sms')
+ config.set(
+ 'authentication_sms', 'function',
+ 'trytond.modules.authentication_sms.tests.send_sms')
+ self.addCleanup(config.remove_section, 'authentication_sms')
+ del sms_queue[:]
+
+ @with_transaction()
+ def test_sms_code_default_code(self):
+ pool = Pool()
+ SMSCode = pool.get('res.user.login.sms_code')
+ code = SMSCode.default_code()
+ self.assertEqual(len(code), 6)
+
+ @with_transaction()
+ def test_sms_code_get(self):
+ pool = Pool()
+ SMSCode = pool.get('res.user.login.sms_code')
+
+ record, = SMSCode.create([{'user_id': 1}])
+
+ records = list(SMSCode.get(1))
+ self.assertEqual(records, [record])
+
+ future = datetime.datetime.now() + datetime.timedelta(10 * 60)
+ records = list(SMSCode.get(1, _now=future))
+ self.assertFalse(records)
+ self.assertFalse(SMSCode.search([]))
+
+ @with_transaction()
+ def test_sms_code_send(self):
+ pool = Pool()
+ User = pool.get('res.user')
+ SMSCode = pool.get('res.user.login.sms_code')
+
+ user = User(name='sms', login='sms', mobile='+123456789')
+ user.save()
+
+ SMSCode.send(user.id)
+ record, = SMSCode.search([])
+ self.assertEqual(len(sms_queue), 1)
+ sms, = sms_queue
+ self.assertEqual(record.user_id, user.id)
+ self.assertIn(record.code, sms['text'])
+ self.assertEqual(user.mobile, sms['to'])
+
+ # Don't send a second SMS as long as the first is valid
+ SMSCode.send(user.id)
+ self.assertEqual(len(sms_queue), 1)
+
+ @with_transaction()
+ def test_sms_code_check(self):
+ pool = Pool()
+ SMSCode = pool.get('res.user.login.sms_code')
+
+ record, = SMSCode.create([{'user_id': 1}])
+ sms_code = record.code
+
+ self.assertFalse(SMSCode.check(1, 'foo'))
+ self.assertTrue(SMSCode.check(1, sms_code))
+ # Second check should fail
+ self.assertFalse(SMSCode.check(1, sms_code))
+
+ @with_transaction()
+ def test_user_get_login(self):
+ pool = Pool()
+ User = pool.get('res.user')
+ SMSCode = pool.get('res.user.login.sms_code')
+
+ user = User(
+ name='sms', login='sms', password='sms', mobile='+123456789')
+ user.save()
+
+ with self.assertRaises(LoginException) as cm:
+ User.get_login('sms', {})
+ self.assertEqual(cm.exception.name, 'password')
+ self.assertEqual(cm.exception.type, 'password')
+
+ with self.assertRaises(LoginException) as cm:
+ User.get_login('sms', {
+ 'password': 'sms',
+ })
+ self.assertEqual(cm.exception.name, 'sms_code')
+ self.assertEqual(cm.exception.type, 'char')
+
+ record, = SMSCode.search([])
+ sms_code = record.code
+
+ user_id = User.get_login('sms', {
+ 'password': 'sms',
+ 'sms_code': sms_code,
+ })
+ self.assertEqual(user_id, user.id)
+
+
+def suite():
+ suite = test_suite()
+ suite.addTests(unittest.TestLoader().loadTestsFromTestCase(
+ AuthenticationSMSTestCase))
+ return suite
diff --git a/tryton.cfg b/tryton.cfg
new file mode 100644
index 0000000..f16e421
--- /dev/null
+++ b/tryton.cfg
@@ -0,0 +1,7 @@
+[tryton]
+version=4.2.0
+depends:
+ ir
+ res
+xml:
+ res.xml
diff --git a/trytond_authentication_sms.egg-info/PKG-INFO b/trytond_authentication_sms.egg-info/PKG-INFO
new file mode 100644
index 0000000..182d7c8
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/PKG-INFO
@@ -0,0 +1,76 @@
+Metadata-Version: 1.1
+Name: trytond-authentication-sms
+Version: 4.2.0
+Summary: Tryton module to authenticate users via SMS
+Home-page: http://www.tryton.org/
+Author: Tryton
+Author-email: issue_tracker at tryton.org
+License: GPL-3
+Download-URL: http://downloads.tryton.org/4.2/
+Description: trytond_authentication_sms
+ ==========================
+
+ The authentication_sms module of the Tryton application platform.
+
+ Installing
+ ----------
+
+ See INSTALL
+
+ Support
+ -------
+
+ If you encounter any problems with Tryton, please don't hesitate to ask
+ questions on the Tryton bug tracker, mailing list, wiki or IRC channel:
+
+ http://bugs.tryton.org/
+ http://groups.tryton.org/
+ http://wiki.tryton.org/
+ irc://irc.freenode.net/tryton
+
+ License
+ -------
+
+ See LICENSE
+
+ Copyright
+ ---------
+
+ See COPYRIGHT
+
+
+ For more information please visit the Tryton web site:
+
+ http://www.tryton.org/
+
+Keywords: tryton sms authentication two-factor 2FA
+Platform: UNKNOWN
+Classifier: Development Status :: 5 - Production/Stable
+Classifier: Environment :: Plugins
+Classifier: Framework :: Tryton
+Classifier: Intended Audience :: Developers
+Classifier: Intended Audience :: Financial and Insurance Industry
+Classifier: Intended Audience :: Legal Industry
+Classifier: License :: OSI Approved :: GNU General Public License (GPL)
+Classifier: Natural Language :: Bulgarian
+Classifier: Natural Language :: Catalan
+Classifier: Natural Language :: Czech
+Classifier: Natural Language :: Dutch
+Classifier: Natural Language :: English
+Classifier: Natural Language :: French
+Classifier: Natural Language :: German
+Classifier: Natural Language :: Hungarian
+Classifier: Natural Language :: Italian
+Classifier: Natural Language :: Polish
+Classifier: Natural Language :: Portuguese (Brazilian)
+Classifier: Natural Language :: Russian
+Classifier: Natural Language :: Slovenian
+Classifier: Natural Language :: Spanish
+Classifier: Operating System :: OS Independent
+Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: 3.3
+Classifier: Programming Language :: Python :: 3.4
+Classifier: Programming Language :: Python :: 3.5
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
+Classifier: Topic :: Office/Business
diff --git a/trytond_authentication_sms.egg-info/SOURCES.txt b/trytond_authentication_sms.egg-info/SOURCES.txt
new file mode 100644
index 0000000..8ba2af2
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/SOURCES.txt
@@ -0,0 +1,63 @@
+CHANGELOG
+COPYRIGHT
+INSTALL
+LICENSE
+MANIFEST.in
+README
+res.xml
+setup.py
+tryton.cfg
+./__init__.py
+./res.py
+./res.xml
+./tryton.cfg
+./locale/bg.po
+./locale/ca.po
+./locale/cs.po
+./locale/de.po
+./locale/es.po
+./locale/es_419.po
+./locale/fr.po
+./locale/hu_HU.po
+./locale/it_IT.po
+./locale/ja_JP.po
+./locale/lo.po
+./locale/lt.po
+./locale/nl.po
+./locale/pl.po
+./locale/pt_BR.po
+./locale/ru.po
+./locale/sl.po
+./locale/zh_CN.po
+./tests/__init__.py
+./tests/test_authentication_sms.py
+./view/user_form.xml
+./view/user_form_preferences.xml
+doc/index.rst
+locale/bg.po
+locale/ca.po
+locale/cs.po
+locale/de.po
+locale/es.po
+locale/es_419.po
+locale/fr.po
+locale/hu_HU.po
+locale/it_IT.po
+locale/ja_JP.po
+locale/lo.po
+locale/lt.po
+locale/nl.po
+locale/pl.po
+locale/pt_BR.po
+locale/ru.po
+locale/sl.po
+locale/zh_CN.po
+trytond_authentication_sms.egg-info/PKG-INFO
+trytond_authentication_sms.egg-info/SOURCES.txt
+trytond_authentication_sms.egg-info/dependency_links.txt
+trytond_authentication_sms.egg-info/entry_points.txt
+trytond_authentication_sms.egg-info/not-zip-safe
+trytond_authentication_sms.egg-info/requires.txt
+trytond_authentication_sms.egg-info/top_level.txt
+view/user_form.xml
+view/user_form_preferences.xml
\ No newline at end of file
diff --git a/trytond_authentication_sms.egg-info/dependency_links.txt b/trytond_authentication_sms.egg-info/dependency_links.txt
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/dependency_links.txt
@@ -0,0 +1 @@
+
diff --git a/trytond_authentication_sms.egg-info/entry_points.txt b/trytond_authentication_sms.egg-info/entry_points.txt
new file mode 100644
index 0000000..fe39895
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/entry_points.txt
@@ -0,0 +1,4 @@
+
+ [trytond.modules]
+ authentication_sms = trytond.modules.authentication_sms
+
\ No newline at end of file
diff --git a/trytond_authentication_sms.egg-info/not-zip-safe b/trytond_authentication_sms.egg-info/not-zip-safe
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/not-zip-safe
@@ -0,0 +1 @@
+
diff --git a/trytond_authentication_sms.egg-info/requires.txt b/trytond_authentication_sms.egg-info/requires.txt
new file mode 100644
index 0000000..6d6abc8
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/requires.txt
@@ -0,0 +1 @@
+trytond >= 4.2, < 4.3
diff --git a/trytond_authentication_sms.egg-info/top_level.txt b/trytond_authentication_sms.egg-info/top_level.txt
new file mode 100644
index 0000000..93df119
--- /dev/null
+++ b/trytond_authentication_sms.egg-info/top_level.txt
@@ -0,0 +1 @@
+trytond
diff --git a/view/user_form.xml b/view/user_form.xml
new file mode 100644
index 0000000..822020a
--- /dev/null
+++ b/view/user_form.xml
@@ -0,0 +1,8 @@
+<?xml version="1.0"?>
+<data>
+ <xpath expr="/form/notebook/page[@id='user']/field[@name='email']"
+ position="after">
+ <label name="mobile"/>
+ <field name="mobile"/>
+ </xpath>
+</data>
diff --git a/view/user_form_preferences.xml b/view/user_form_preferences.xml
new file mode 100644
index 0000000..d8efa40
--- /dev/null
+++ b/view/user_form_preferences.xml
@@ -0,0 +1,8 @@
+<?xml version="1.0"?>
+<data>
+ <xpath expr="/form/notebook/page[@id='user']/field[@name='password']"
+ position="after">
+ <label name="mobile"/>
+ <field name="mobile"/>
+ </xpath>
+</data>
--
tryton-modules-authentication-sms
More information about the tryton-debian-vcs
mailing list