From 2d71deccaef6470c4e8e41c8c937dd0d5ef7d162 Mon Sep 17 00:00:00 2001 From: Claude Paroz Date: Tue, 6 Nov 2012 17:54:33 +0100 Subject: [PATCH] Initial commit --- .gitignore | 3 + COPYING | 662 +++++++++++++++++++++++++++++ common/__init__.py | 0 common/settings.py | 122 ++++++ common/urls.py | 29 ++ common/wsgi.py | 28 ++ docs/SchemaRelationnel.odg | Bin 0 -> 18726 bytes manage.py | 10 + stages/__init__.py | 0 stages/admin.py | 46 ++ stages/fixtures/test_fixture.json | 125 ++++++ stages/forms.py | 12 + stages/models.py | 126 ++++++ stages/views.py | 67 +++ templates/admin/base_site.html | 10 + templates/attribution.html | 137 ++++++ templates/corporation_summary.html | 5 + templates/student_summary.html | 3 + 18 files changed, 1385 insertions(+) create mode 100644 .gitignore create mode 100644 COPYING create mode 100644 common/__init__.py create mode 100644 common/settings.py create mode 100644 common/urls.py create mode 100644 common/wsgi.py create mode 100644 docs/SchemaRelationnel.odg create mode 100644 manage.py create mode 100644 stages/__init__.py create mode 100644 stages/admin.py create mode 100644 stages/fixtures/test_fixture.json create mode 100644 stages/forms.py create mode 100644 stages/models.py create mode 100644 stages/views.py create mode 100644 templates/admin/base_site.html create mode 100644 templates/attribution.html create mode 100644 templates/corporation_summary.html create mode 100644 templates/student_summary.html diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..353d9fb --- /dev/null +++ b/.gitignore @@ -0,0 +1,3 @@ +*.pyc +database.db +common/local_settings.py diff --git a/COPYING b/COPYING new file mode 100644 index 0000000..939a6f4 --- /dev/null +++ b/COPYING @@ -0,0 +1,662 @@ + GNU AFFERO GENERAL PUBLIC LICENSE + Version 3, 19 November 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU Affero General Public License is a free, copyleft license +for software and other kinds of works, specifically designed to ensure +cooperation with the community in the case of network server software. + + The licenses for most software and other practical works are +designed to take away your freedom to share and change the works. By +contrast, our General Public Licenses are intended to guarantee your +freedom to share and change all versions of a program--to make sure it +remains free software for all its users. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + Developers that use our General Public Licenses protect your rights +with two steps: (1) assert copyright on the software, and (2) offer +you this License which gives you legal permission to copy, distribute +and/or modify the software. + + A secondary benefit of defending all users' freedom is that +improvements made in alternate versions of the program, if they +receive widespread use, become available for other developers to +incorporate. Many developers of free software are heartened and +encouraged by the resulting cooperation. However, in the case of +software used on network servers, this result may fail to come about. +The GNU General Public License permits making a modified version and +letting the public access it on a server without ever releasing its +source code to the public. + + The GNU Affero General Public License is designed specifically to +ensure that, in such cases, the modified source code becomes available +to the community. It requires the operator of a network server to +provide the source code of the modified version running there to the +users of that server. Therefore, public use of a modified version, on +a publicly accessible server, gives the public access to the source +code of the modified version. + + An older license, called the Affero General Public License and +published by Affero, was designed to accomplish similar goals. This is +a different license, not a version of the Affero GPL, but Affero has +released a new version of the Affero GPL which permits relicensing under +this license. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU Affero General Public +License. + + "Copyright" also means copyright-like laws that apply to other kinds +of works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further restriction, +you may remove that term. If a license document contains a further +restriction but permits relicensing or conveying under this License, you +may add to a covered work material governed by the terms of that license +document, provided that the further restriction does not survive such +relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Remote Network Interaction; Use with the GNU General Public License. + + Notwithstanding any other provision of this License, if you modify the +Program, your modified version must prominently offer all users +interacting with it remotely through a computer network (if your version +supports such interaction) an opportunity to receive the Corresponding +Source of your version by providing access to the Corresponding Source +from a network server at no charge, through some standard or customary +means of facilitating copying of software. This Corresponding Source +shall include the Corresponding Source for any work covered by version 3 +of the GNU General Public License that is incorporated pursuant to the +following paragraph. + + Notwithstanding any other provision of this License, you have permission +to link or combine any covered work with a work licensed under version 3 +of the GNU General Public License into a single combined work, and to +convey the resulting work. The terms of this License will continue to +apply to the part which is the covered work, but the work with which it is +combined will remain governed by version 3 of the GNU General Public +License. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU Affero General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may differ +in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU Affero +General Public License "or any later version" applies to it, you have +the option of following the terms and conditions either of that +numbered version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number +of the GNU Affero General Public License, you may choose any version +ever published by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU Affero General Public License can be used, that +proxy's public statement of acceptance of a version permanently +authorizes you to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as + published by the Free Software Foundation, either version 3 of the + License, or (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If your software can interact with users remotely through a computer +network, you should also make sure that it provides a way for users to +get its source. For example, if your program is a web application, its +interface could display a "Source" link that leads users to an archive +of the code. There are many ways you could offer source, and different +solutions will be better for different programs; see section 13 for the +specific requirements. + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU AGPL, see +. diff --git a/common/__init__.py b/common/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/common/settings.py b/common/settings.py new file mode 100644 index 0000000..53f9a77 --- /dev/null +++ b/common/settings.py @@ -0,0 +1,122 @@ +# -*- encoding: utf-8 -*- +# Django settings for epcstages project. +import os + +PROJECT_PATH = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) + +DEBUG = True +TEMPLATE_DEBUG = DEBUG + +ADMINS = ( + ('Claude Paroz', 'claude@2xlibre.net'), +) + +MANAGERS = ADMINS + +DATABASES = { + 'default': { + 'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'. + 'NAME': 'database.db', # Or path to database file if using sqlite3. + 'USER': '', # Not used with sqlite3. + 'PASSWORD': '', # Not used with sqlite3. + 'HOST': '', # Set to empty string for localhost. Not used with sqlite3. + 'PORT': '', # Set to empty string for default. Not used with sqlite3. + } +} + +# Local time zone for this installation. Choices can be found here: +# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name +# although not all choices may be available on all operating systems. +# On Unix systems, a value of None will cause Django to use the same +# timezone as the operating system. +# If running in a Windows environment this must be set to the same as your +# system time zone. +TIME_ZONE = 'Europe/Zurich' + +# Language code for this installation. All choices can be found here: +# http://www.i18nguy.com/unicode/language-identifiers.html +LANGUAGE_CODE = 'fr' + +SITE_ID = 1 + +# If you set this to False, Django will make some optimizations so as not +# to load the internationalization machinery. +USE_I18N = True + +# If you set this to False, Django will not format dates, numbers and +# calendars according to the current locale. +USE_L10N = True + +# If you set this to False, Django will not use timezone-aware datetimes. +USE_TZ = False + +# Absolute filesystem path to the directory that will hold user-uploaded files. +# Example: "/home/media/media.lawrence.com/media/" +MEDIA_ROOT = '' + +# URL that handles the media served from MEDIA_ROOT. Make sure to use a +# trailing slash. +# Examples: "http://media.lawrence.com/media/", "http://example.com/media/" +MEDIA_URL = '' + +# Absolute path to the directory static files should be collected to. +# Don't put anything in this directory yourself; store your static files +# in apps' "static/" subdirectories and in STATICFILES_DIRS. +# Example: "/home/media/media.lawrence.com/static/" +STATIC_ROOT = '' + +# URL prefix for static files. +# Example: "http://media.lawrence.com/static/" +STATIC_URL = '/static/' + +# Additional locations of static files +STATICFILES_DIRS = ( + # Put strings here, like "/home/html/static" or "C:/www/django/static". + # Always use forward slashes, even on Windows. + # Don't forget to use absolute paths, not relative paths. +) + +# List of finder classes that know how to find static files in +# various locations. +STATICFILES_FINDERS = ( + 'django.contrib.staticfiles.finders.FileSystemFinder', + 'django.contrib.staticfiles.finders.AppDirectoriesFinder', +# 'django.contrib.staticfiles.finders.DefaultStorageFinder', +) + +# Make this unique, and don't share it with anybody. +SECRET_KEY = '@2a-1%9w4rmw#(mi*3jlb9!9#kj0a8_g)6$4nv8zt0h(9r(wb%' + +MIDDLEWARE_CLASSES = ( + 'django.middleware.common.CommonMiddleware', + 'django.contrib.sessions.middleware.SessionMiddleware', + 'django.middleware.csrf.CsrfViewMiddleware', + 'django.contrib.auth.middleware.AuthenticationMiddleware', + 'django.contrib.messages.middleware.MessageMiddleware', + # Uncomment the next line for simple clickjacking protection: + # 'django.middleware.clickjacking.XFrameOptionsMiddleware', +) + +ROOT_URLCONF = 'common.urls' + +# Python dotted path to the WSGI application used by Django's runserver. +WSGI_APPLICATION = 'common.wsgi.application' + +TEMPLATE_DIRS = ( + os.path.join(PROJECT_PATH, 'templates'), +) + +INSTALLED_APPS = ( + 'django.contrib.auth', + 'django.contrib.contenttypes', + 'django.contrib.sessions', + 'django.contrib.sites', + 'django.contrib.messages', + 'django.contrib.staticfiles', + 'django.contrib.admin', + # Uncomment the next line to enable admin documentation: + # 'django.contrib.admindocs', + 'stages', +) + +from local_settings import * diff --git a/common/urls.py b/common/urls.py new file mode 100644 index 0000000..0235cb9 --- /dev/null +++ b/common/urls.py @@ -0,0 +1,29 @@ +from django.conf.urls import patterns, include, url +from django.contrib import admin + +from stages import views + +admin.autodiscover() + +urlpatterns = patterns('', + # Examples: + # url(r'^$', 'epcstages.views.home', name='home'), + # url(r'^epcstages/', include('epcstages.foo.urls')), + + # Uncomment the admin/doc line below to enable admin documentation: + # url(r'^admin/doc/', include('django.contrib.admindocs.urls')), + + url(r'^admin/', include(admin.site.urls)), + + url(r'^attribution/$', views.AttributionView.as_view(), name='attribution'), + + # AJAX/JSON urls + url(r'^section/(?P\d+)/periods/', 'stages.views.section_periods'), + url(r'^period/(?P\d+)/students/', 'stages.views.period_students'), + url(r'^period/(?P\d+)/corporations/', 'stages.views.period_corporations'), + # Training params in POST: + url(r'^training/new/', 'stages.views.new_training'), + + url(r'^student/(?P\d+)/summary/', views.StudentSummaryView.as_view()), + url(r'^corporation/(?P\d+)/summary/', views.CorporationSummaryView.as_view()), +) diff --git a/common/wsgi.py b/common/wsgi.py new file mode 100644 index 0000000..bbe7830 --- /dev/null +++ b/common/wsgi.py @@ -0,0 +1,28 @@ +""" +WSGI config for epcstages project. + +This module contains the WSGI application used by Django's development server +and any production WSGI deployments. It should expose a module-level variable +named ``application``. Django's ``runserver`` and ``runfcgi`` commands discover +this application via the ``WSGI_APPLICATION`` setting. + +Usually you will have the standard Django WSGI application here, but it also +might make sense to replace the whole Django WSGI application with a custom one +that later delegates to the Django one. For example, you could introduce WSGI +middleware here, or combine a Django application with an application of another +framework. + +""" +import os + +os.environ.setdefault("DJANGO_SETTINGS_MODULE", "common.settings") + +# This application object is used by any WSGI server configured to use this +# file. This includes Django's development server, if the WSGI_APPLICATION +# setting points here. +from django.core.wsgi import get_wsgi_application +application = get_wsgi_application() + +# Apply WSGI middleware here. +# from helloworld.wsgi import HelloWorldApplication +# application = HelloWorldApplication(application) diff --git a/docs/SchemaRelationnel.odg b/docs/SchemaRelationnel.odg new file mode 100644 index 0000000000000000000000000000000000000000..464c146b8c378ececdc6ef8908200fa8978b9d1c GIT binary patch literal 18726 zcmb7s1y~+Svi66&YanQF_u%gC9^5|MCAhl;3GQyeA-GF`;O+!>f;&It?71hqd-nc& zn`gdfX1eO_>gt*9s-|k>rNF?^0RU(Kz$(y0AQOzPhZ+C?ydE#N09HUNV@EezV|`m& zOQ4~?Bhbd0-r3rS&PLw>=s;&1fFLyI`EZQ*-`m=#M+DmOyI@ z9%3^`M_W#MdKVWLIu~X-8+%iFMh*@R`d_ug|7gm{@PFuRo$M`tQ5hN18(SK`cHM!V zk&co6Puf=r|68G6X@3{V*526R1@M=i|67dTd49*Tv9b9dpUtF1DM(y8NCSd?}PFpGc&y@ zy^+47KCLs**yY`ylK;_<|Gl>y|I%9{dwrMxm4lIi{*{K9@DFs(-yT#ZV%|TW%GcrJ z<^DB@Kx?2QQ2#|O_Qv{-Huk(imikUc#)RDTe_Q(p&oA1S$Dj74Q^veZ42(>)jEuAl zY|4!9IT=_vS=s-={m*pVMuwb!!@$DK$;8G@|7YbZ)xXK|+r2*|FgALT+S-)X$jScK zNbt%lGc(DsD*dD3f2;myE<-m%OJfJ#msWpu@=xl2-2Q{s)Y#hi1^Y!K(m(@yW4T|i zGd(jMD~UAF+R0T{ot;gWjfL>HN?luf8*^hrM|x&f1}jDqK_{T45iQd{+V~6Z4|rR9 zptYm15v_sSzi9loir*;zPSeaBoGgE8`WM$9M1OGo&%ERC`cgVL0u2d&_0`7URm7K< zz{%Q?hnR_pn4XvWAI}))E5Tn^|AX-B_8*fYG&Jp-ddHvNL7Ac`+@y_d>ZTA#*qo4)c?%#-cph0V%P$te(xqb%!V&8{ zu~0v4%R_SntPbo2V9iDoDDl1%fo1<80;)X_-bJT~6nj+r<9OFVyuPibCuEpFiJ7Ry zfD8@1)5_LGYMv#I79BSEbkDh{pDz|g9+o+~5a2#wa2Pnl^CXVyfV9DkJ33F@ zr8#E~eF)2R_DvM+@s-*=bm&~WQ4Mr3a;%;v#q7@7I!yis5oZ@eRa`V6dM@lwRM`9e zY0kfaq8B+v83@V{Y1wMqNX|y?0=h_l zlNc2IP@x5OdFJ!`fG@jICe!XR;Y}$*Ur6fBY6z?*$eCnrVc$ zQW4KQxLJz!vvp61h8f2Z{YJ%CiyJ-=(FxU7BwVeSK3%(WAS2b5(j1XfBVc1J06gIh zp_19yWfie+(xKrd|BC-`R_9Nd0kPrs30iZgJHZ+Bjw>PZ;YO5e7r5p8A6fR=U}`D? z`vkKqRS7?z&pMD-ug;-@ns=ER1wl4W^DZ@L&F7y%ycVupcbzD;N8jKh-Ih&{XD4VP zMB+PnVlfd?NX6vB!XV_&!hEK-ZFz({aFsH_qs1TmAfoh6vOJx8q_>z5l?OzHr(nvH zOsuw(l#QUVaS@aK(sdHZ&g&y&=Oza9>^9Y(e@d8%J$7?tU5ioi1uy$L9`BJ_T5S=d3tuK&+F(Y)1F}w^6y6GZ|%;Pc3$2-aX%5npFoz;_r8_6?P@he z(`PVDIS!3GJehM{a{I&6KlJbOr1#!-8{vFy1~=9ljbqO`wokJX=_mVC$B@is6rv+W zoHP72ChLufLhmQ>Lat5u-Q_&aF(Us^2I(0&GRYpV1Oa2>$TZoU3B@&RWcK*A$1cZ6 z6(_XND`21PP>cq`aDDGE~5KD{Y`@eS;C->=WupnmNhh zHl_!CrtauT@!+X&>%g}d~&| z{)vrhBW&@*974nql9h&C4fCQC_YkXz4?JI*D5lnC{#Y@%Ky%4?)N!j;<5rh5g5`UJ z1!k?3+Kp~=c!!PIEW%8vjXqai{K(dZrK~ZxTgDZ;pZ9Z9ez0`y*mcKU#E?O(hTAOW za{i*}5y2mjn*8bMx5HPwTanT}>1#&%U2#{KruV5Wn<0XIi}TJ{rKfSpI@tRBl!MXa zuj$D!5wV_CU)DYY_d$tyKLOat_VzPZpDi0>o!vVFEfAVD+sDT!Q^n4Bas`|_who5m z6)9-XHYaoh*EJ4BM2XI=l(EaxH$X>C<+MW^Bg8hLIF8HmvI#zUDJbYFkkBd)NC04# z6ae_oOAg%2l4EG|vVOi;?=LIP(FcpD#Q~J3OeJV-aB-j0@$U_5$${(3dSG+7-ORX~ znVm#hsQPVVd3njL!d~0(9Aeh7ad}O*$dsWepM!9CxWVQyn@b12RFv+Q9&ZnvczHzR zj{A*qOUL2DP^PdDhh{?RGqry5YJM&~6z5xcTK~YA9Kibqs+ccYLUF(=1^x5{x;D;3 z`)WnpAtgeI9_iffM=uEh))V`8aYc*B#RfcRv#Qcya6Q`nEeyh#!!`6(jFPa zA=xl&xu|^dXGO2_Tr=h*e$r#ISm0v>oXZChq@I^!p{Yu3_~Z7h0-pf+^TA|)g6_Eb zg@$xJSb|))^xUvwQ+Z|qkXgAv9+HcIZiYpOwnA%SDE)^N4rV}o&tv+JHmqBOAHWs_ zmKY%_@d2Yw?KT)^Q}elBlO0~^w}y!14|5<0HmV3WBK->qu^ z=J5+JW98>Ck`6_8<+tHmLsF?oH6+7L{K$Tg0OUFmL~Dqn?v$_(%0&uUpzFiBY#lKs z-jJZVp~P+>DF&xIa}_jiCvi{n6?O$KXjdwM0IA}Dek>#k=_okkuuNx3C^$^DEg>AO zZ+F%Rk)eTX)))WnFd9{ z&hK#JGkXxD$|u)HpRSe>ddIoWH(?eVwZZVolq78g;3#8f*&m%8X+AXY0dqsGlKu27 zdCEFg11>&PL7-J4DW*dG{tk`h)0%jPUT?hA83NhKJebsD za|bHr7iSNe$P-YhvfT=we7CnWnL;F2yYB_p>*Xf~hZyvFiwg8iRGJAWo=16%~w20y^opg za;wJ77LxiR(LpD_u-h=F)n3~Ea8$p%qO9n$YW_H>yUdRraF2j$NEW{EZ0@$<;U*-no?jS~q~!RXA(~h*Vo-Jl@mjvYSa6P=cmUC$eI}$%>g?+)kcvOunU%6844W?3>9u-7?=u^7A0q?~o^;grE~F@=ApUu#t&& zs8E<*uBrP}h>Z|}V!RS==DOD%^4%8Rz!Pmqp4V~_3eF}MeqzHG-Zm!PS9MXbC~e*O zsM0Tl!_A5{4YG2?)wc63>gV9{Xf>PZY|(tbxA~Rct%P1(Zdx~NO6IeQr%UPMygfmJ z;Q2P~O{iW?`qKRRqxQA%3Yxny#FNC1NMoRu4EO{F-lAoW`o{hPxPGB^z*a~(_SQUl zvzNi-&O(xnSsDIA46ka`XO-hIyl+S8eD^2b1~$SHJ<&hVP$Rvb9(=9ZUk^D(L$FrzAfAaz|rKqAC==@jDFtHH`!Z82+2v`Jw`?_t~O>`y4k zc7O85t2fPxRE3|haS_9ezOicQn)x(0iw~aj+C#MIkiI3D%p-8>>FVHdcecGdbCuWY z?Mi@z`1ud&W-kb(r=L$l!MZEnw{h8zZmv?qCz9}P&_Kp}9M@h8^|Q(Q`^@0?MCX%h zDm&}YlWW1flljexvL1ahx}zitU{cq%ED3=H3Q`GRCu5QPpG2RtA%8AW?o-96U&RFUU(v)XwBjbVT7+ zm=%DIWz&ZnnGO|+LGn=q?UYfPunMcK0HyVuaJZ9899?|Q_OMk$8Ou;%NngPOIotrk zNkdt{xe%5ihE>&dz*H5_2(B<54;alv-`qrq{z3&pH;q8E$DqwZ9E$2A5@t6 zN-(#0@bo6Q&F(gvUeB+6!J0j>yf`t*fhbwJBerJHh@NqCNi71DO#3RVs##OGUz3^> zkIo)agIaJtl*_oNn7unOn=hZC-6p*E#G=X!u~D7-Qc$5%dy0#wgus;|XI(Z#)rMSc z!_j|GniR}<3<=J3 zO!GS`4{&O^7D0$dCgqobY+ryCAb}-Sfx-hn7eq>@f&^(RX%YH_dvm_gODE+v002Mq z#1z+>Ge^CVb|Nt8^GezSP0}E9P0nW=wk)GHT6DT8R1ydxf_J%7zux*dJTxza%v?`o z!b|WOJGm~gv8i!P2B8Ltyu0)f6Vid>DkIN629lm;(5uKGt%roOtTi$D!VAp(x}hL_2qn3ctdJ$SXpo+)-vZ;U2( zS&UvsdT8Rhlcr;nETqJDN+h)F?xB^S#6^Fsg;S8; zH|AtFak9wJ`@OogsSis6=PF4oi`anwuddELc>1?e{L*-?~5MXg$FaQV=;=+mm0LaTJ zpbi@J<(E&dUI+jn%9aooP0#(5X zLuAwlv-x1YzPY)yxis{6{CGV7#8Rvb%YZEvXtEEh$4~$c2QVDh1JR?wp#emQ_(S+q znNz89$D8(k>L^yK#;xqKRn3}t>?S52L*K zp(JMufWEzgNSoF0SN8&pX&gVDc&&f>+*exqWoV_rXfpcK56I#?96&|7_j5bS1GTUB z6VwB&eq8@2e~ew+0|Gw8%?v7g#I10s+-R$&gh0tFmpaCEJ2nRzHGto(l#9mB3F<@iM}^+z>^$XMUk(P&K67;*_ScvZ|`;2Fu{Ny+`v0 zL;w@W*IV}Hema}EdrB&|@32!BCo~-wNnmi|B;GA&BTqwI&OYC$wLRa8ksUYHy1)NK z*am71UFA?GwU8FD-&ekkFUg6GlXSqc#!4mQd^h97j_Ghz!iN85%9c%x$vq3hM_2y{ zU3qf#jpw@rx-jj>(PnpNRwL8w=p(*rCvQ!7n)y|u{;ybiji9^FnclQt(%;UrPmD-1 z3Dd|vi9OAXnF8e3v=oaS4Q{fO5A+X~AhL3T=7c>?W>+8Q{YhOiOb1}wDKu1Xa{zMo zu`ZJmhFB#NzCP@9_-z`vA zX@f*~-#lB4NVv(ev`wvz$P4hvqw&UxV4pExyOD{S~EA;PVt!pHj6wI zSWN&Ttp5W<=#sik`V%Nzci6nBy)|t)S~C^di*{9O~$04 z;V|NbEmG$4ZB0c#l2ASikxioqOn^OI9)U#8AhdFBRl}^XC1RMEq}H0}WzN zrpc6}i}yvxu7AMjgB1Bb@YP(I*2BmN#0`yN>wy%JTb(q$Sx4A8Zu^vk9Atmvq=x6L^T4%*T@no#uI*)F+W0eXMU@_0zU$bt&>gHD~U4fI;JF0 z?pqx1Izcg*R+N#4hE_XSB^I{$>rgeOZ|2>8GiM|AM<~|q&LkSut?qm~&1A8fQ4xQ> z{0-MT^sU)a%BAcDYDaeMYEH0;%6u6Dtlc}N(XAPQ{^HFf#sX5~8FnSLPU&$efL(4% z#S`_gSNU>=Of#qjTxJ9T!TOT6t~*q~1DfV2;tKC>5^jL97OwupgdBp3A$*_DE~(E@ z#gnf>!h?IhdAz=H_j_Jg+$w zO|0|s9(xhkJbctuu9PmS_w!>ju?sl~A&_elgJ@TW=4E5UG{=3KYOLQz!u0tVmfvPb zDZ7x^fOj*v7P|_9Es`f<1*TXNHcNx;URs$nP-fv=iW!CP;kqhHXmg1>)t$2|}yKW^eOTRqTk;pD7VELhFVc2?=wS+*0=l1IP zl9@Q&y`95$jM;UW)LxmsJ9(BsEHZja^>~fRlc}P)o28{%7BFA#Q=SAPbp=)n0GKo} z7+{QeWgQ0`luUw!O-ANORbZlL7w)1cQo3psDS1MHU?j}U{@A#U?CC6U7IKl;GxL)j3YuUQPWD@i=T+$B=ucB3dJ;yBDjXf~H9cY9= z+acgQswcRMbvm3c6FJA1$A7=nWLq1`1YD3*n8eVUwRLuk-#1QTf$KS5xO1eQDm#c? z|0(8YRK+WrBO+K{LUX0}K~0e|-i!|;`-<@bm0!-LzjYT=+9{&3@6Iiv^<3!7v?2Aq z;$G_;bRw&@a6K)_MEytFn9oKT4^?dMz4^2=I*tz#xlo|;?qbK|M{^_%dbDD46d3N_ci;>kFh5JNVP3eg=v1M5 z=#I~*k4AgnGDRFK2;-+NyCr{yf(GmC>}+a$uyAg|Veo!;d*^5A#|ils(! zdp4d~w<@y<=BRTHf1?GL=W-GIiIn&J^JHJ|N~iAP5Hag(=Bc{bSG-c=$Ggig`UF|@ zEc?&=+vLOYcgT1_U{3ctzL~{FzCKF|0e2i!WM=5d4`RG!M4$ZG9X1V%dnOm0TH^aE zfp=bCqvbl6g9d)mA!ZO<*On|-8_eWk`EfV%Ip6OvfXIw2^tc2}8V5nO>Dj0w)!kXS zEspuv4c#+_SY0;on@1Z}WRUZlQ_F8Ru8um`8y1eB&%QlI9xFfUXNI_Ti}HQ308pvW zGI%Jw*9P2Fo!-mZo{`Jwnsny{MR`)5;&Nc&-oUSYxQtiBujR9P?h4@OuqiKlD)jmq zYgZf9es@Uz?Km_4<8X!_>>|5dFu8z}RlYb4A~q#6w#>ck^h~siy2(wLG5-9BZFtGR z*SQOdWtZNW2tzJ9-LKrh3DDE(cY&H8w)87%Y3un*US_6cJ`@QT~BV-Sdj(Unk6B)Vf^vAkPuSW1k;WB~f@F*_gHIhB3 zjMyCT+nd3hJg`pF-Vbs6y_d1J!)1v2fteL!R4}S&I2namIa_Yw1u4ej!>-D||1&Kjt# z2DkuVKT^YeKt)|neYo)5l)Pz(DIf-#PW#8eA-MncXpZUgs@&MK_A;wVl`YLctRhc& z99dT?cEg#w8H0g<5J?>X&`J}t5H!w?)W?1$Y+y-F%jLfHKC_gSyJSt3P~`#@aCTsM zqx&N~5eFJJ{DzVK!;w~)Rr>o1l zlA)Zf_)Yjs-&&<@+?2pEqgi(`dY3ZtQ(+%n*-S;?Tev*fri1PGFd}Rlhpj)Xwm%$zK7)QDoXJbTFD|^5{5cp@M5AgrBS19 z1r(E?KG#OuvOT8iRWvQ2Wd*(Cj)cdU&Ea|xyU-QTG zgt1G6ScJ9TH2L`btymm!Z(=x@9tiHC?j0Q&Ol2|Vua?C>wQFB3fW}u~TMl_d!SxAt zuz~&ZH6y}585|Y0El#R)LBD9&j?r}qr(3j+NDgo+31F2JG@?$Yhr~9_(ocX@sjjZ3 z+e#3DaHkBa0(xt*yz6p11l6ddOe#k2gKTLjQkHvRJJSOlE}*3S0I{Mts0`l%;o`nX zAFYQ2v0@HKiKqcD_cP>O6a*wpi!s0S%DqVpVt)o*ad~zNZ)d^SkWBJ)DX#>hYaRr+ z8|WBOy_}i?`4|qqFo=UzUv~g2W7fmR+PwOOx5{rk{baHe{c)5cQGg%<`^@}uhWCyb zPN3!MAdUzv`IytOoSFT!ax?h6nm2t~xVwn-KWfeozGM;633myORZ0d@O(0f@Q(Yov zPIuHaee{CU6y)CW59Agb7a5U(NpO3-GPGMx_FcI!oXsrPVr<;h`K+`~dkxiXKNPQq zGK-4Z4+fzON4F@`(i(lBF*ecx)V>xH>yEaIf&i z3zPIJur(QB+Lw8TP~+ z#;(5Ia@q*TAt_#`WR&X1CQO!)dWzE8TcEm|Dr$~$LcM7 z((kO-v(?w7=4!CbKX1O6l8Ef0H!!kscTU=)xc-5bNN0t@hm_#F=Ta~<7r!(ljvNql zj((%oaGfT)rMZQfu9;QYbVm`Ck~?`+l_jO6-D0%>A=oUGPm7X~fY0(d&%btgeE3Ii zxNnPL>hAnXgAIWs2?>)bI692qe}w6m7CCimQ==X;EA7vJJq^78ZJ3!JGAzD*J@Tavng`j|eSZ%qkAT~pL% zczW;!Svp*3)cl7Lm|%qR110A@ie>n16YW-La(+p!eC7^ySuoR7ajX~Gr(|C36o z5oSm(vR)7?OV!yS&|ukwZGsG_p9 zx=MQMFz;8$38nb*MzY|@V1ARwZ@N90fb0SVLDaKxhpL04yuwsXcqU75&G9T?_0;t| z*?ibUCq6c?v^1L`j_kDdiz0ixt;#ki`u)HM(8AMnnfm-M8e%>56ES`Nce8Nycmuztz3bRB5Y`^tISd@72!%-*`=Y1w91?O*z<} zbEA&OTFIwYKqU&#tUTVfxFTH~J`mZdK)VI(Fw%-tzx%PnF2J}D&G~TwrJx;8S#W1E zd>>m$Q^Ec-7WWqkb=d?rBH~?h1fd!5FK#|Y1U3B4abQb)Qjv%ggX!irzG-A4ZsLnn z7sn4T5A+xu+ls+5(2B$ThmilAKz3BREd$j0%7WXGu@sQ$F z962w7!un%&-E#xDtza!|e0iTPJ3?%pr(MrAE2{X%;F?0TLChHA@mLn4Du?6vqAsDE z6;eE(cC&#sCJajk3;Sn!AFqDg`jb9E?6i-pEf+G2g{OQeLaB6f2aLn zESHG;?d{RTII-FdyE=_k>iA_KGPZ$ek_10O8^#-~RQ&w=FLNn&mQXmL0G;D^2UL~7 zm%*l#_(_rdz2zpW68c9WRT$n1*z(dCA%Lg9{emBGr>z+x)=fx=i$W>~uZfNY))aLb zarK$qyhI`0S5j}sigR`}D+^NhHh~@nHWM4vXXU6qx-7a5^bL#wbVSC6u5>$HOtP>m z+uAfb>kaCpZ#KW$NII-jRNpi0N#S1D^t<`dOzHz6W!Pf?1Ucoq`Xs^BDkp#IxhNJJ0FN(}T4v1jB}6tm*DwG1PHa9G1` z3~7x#kwt+dAQxeV*&)34Jf60A*S?$%H*J+zHCSZT4BNuL>`@P*zkd(ilM|zSiN%p~~dr znuONusmizl?yPl9TBofE;tQ6*)pqjK%)C`vt6G`xl51mzc`w?c^YTV^h`zg@`|>2# zH$4#S46I!3OgW!e+Q-;A=xsyfURhXFIa@e5*Z@eGm^0AjD>Zfq?V6&wKGWp7m7& zG8aVg1hAPI{#9b7Hj83D2;tN6G+9$Qnsf1Z-YlwAhKkST}ot^SV|<)cW? zUXm{HM!(E?CT$Z3H>YGFlRJ*{y(1QCcQ<{%llBug=< zxO99u$m21WgfJosBVrZz7G7^6C7kX@tV!H)w`@!M8Su_yP($Il4_X9u)VY**q(|hC zm%sMG_E{LAUsNL=pR&v(_Y|Vqy)&CpU#0(Hu#tdgYm~u?uj6s-ry(5L%ugH_qjXLl zhjFOGT?*3nDJa^QY(G=rq_oLXXU!eHq$v@4clS=|`XqN@I{gmcky*{BLVC58^28uO zvH;HZCMIZ6dbPrZl;;>|HYT+{OTe345qLveP)o^GO&-MCv|zsU`N~I!_-GSo5Ohw( zzY1!BlSYTro|E(e06h>5@TICFU#7kWC9d}?gDeM zU-A*K-;EQ|ELWOTNL|D?`03*QPzQ8eylj}%!**tm7Vth&7>D*BQc8yBUb65aM{<;v zt0eaRl)&&oj5N5z6DTqCybjSlV(@?J^iBPoNJwxfA5``hQvh%1W@N-|FC}>CN zG4z!VQKxy@jFa>6fSAi<$8f%UaJ~Kh90)PND(|D{L8!UGvkVFm!-Xj>Umd@^2d(h+ ztMy>JCAi%4M>@L|LHtRoE`f<*L!I_Vb!`XiCZWej!ai5qk>|?owTgbe71r`gTkZDf zY=}YH;cHWRL$=iz=*9pD#f6f>pT3TW==>#starndr$G1mFCl}cU#Q?N7mGKcHH6Tp zM>EK}jH&S;=o)y51wMSGXnjTIZxCw8C^GYUp$fjtXfb-7+&SvIhRJ zdNFS}^cce9%4r^LlHwQZny+~h)bH(yLeUm=8-c%Vz%DIley$$vNVH*;G6Giqi`uY5 zw`1}4_>_8ERB=+5b45<;8u)Y81@Nyc_TSRQ9tP{}LLZQ{ks{2tlxBR0Z_~kQHozI z)7|utJr=(&Tc5{`H;bbTc7bxCmh14w8qBGiBUd`)u>Z!dha-%H}zAOwVN5O4?1eh_iCWrgUoHr;VhFE2E+|7PT80B9v zG63b|>HyKr(u%e*WMnOjUYN1nt%BiwmCQV4URSf7Cj-^m4C-|~^p_=zI0ek0G>07o zr}gbrQc8+Si%I94R$woGILufHp4|2-hOuTPAR;8lXRf5^OMsyjAMaldy9zH<)3G%0 zvDFNBCT(}^@L*J#oPT3cQ0^61Qx+iR$OXXOQsV)lVMTo1=Kb7P+lQ8Q2?f^?V#WdT zcKisS7k{!O-H3+%R!3KU3FP#U;PI8y@`%jmT@xN40+mKfRGi%d`YNoW#v2~wW!tJ7 z-t_sx{6!!LYp*?w7d=2M;Y@1%-~OK{Dh7hC&AvJ}Zf?x8d+2{(n zQgbx(hxDa>@AtHUb!|SoAG=FHUo^5yJxxMLA+lvS!h`Eo&<|6#!Fp-7*H z(@u~vzmIa0=bZaPU7ep+*5kiH)a~l(1oK%|7v+PpNGcG&#c(<3`RO{t*5|RO1Gw&` zkz+VB2q#?ewaaZQZ`ELfI$69BVm2k8+TMAIjQ23;;*D=_xt`6bPiBElSZB7xmgajS zhljr{f`J9b&~d}%*SRZr4SF*aA)yE;fX$4G48ex;scb_v@k*u9y>glmp6C0qm7>t2 z`ebo;p9_i|@g{eg835rE5;Ee3J@dE}sX+iAq-;x#{9Ay-zit2h76ozZt%fVi4O)3V z`Wm_+AtEdMMNrT0pEDF+YyK<*FDF7a)+RvHeGbP}1d#%1LxeIK16@fV z3SFxvI$RXBCM|4QoH@}31igfQB<7bZK{;d5i=n<03*%YMST2qk^*v|HpXLw4n)7wC z;42ZVs!cw{78z$%eJ&V6lwypdQZ#!RSS}HmnTa}N#*L?s-%Xg8hYPgJ9#8l82WKZ{ z*1t|uTXfc{qTUCfuxe}tPmVP-aeQ(u^Ol@-DlR(5K*`PSL?tLQrxb^vLjE#1WJhmr z#d+)0jGz9Y;Q%CQ13rA*tstSfm`SRyaFE8%%7LcF_p>0pPY^N}?=xWg(p*FtLUKCS>MO4LUWWu877Ym^-~0<$cvyDZ;< za>-k^%w4|vgts_8NZj>)qr~*m{o@AQewpMZ>_1CD=o$pnrrLTH_uBTTR ziQ^&gdwt*AObhwsVinEju>YZ5kv_!}Ud6l+R4^=ux zj|py=J%%5@3mbM?9TP&AyWLHf6yjN0-mi4nb5D#6LKZ0S6z13N1wtgj{Z7tIg{eiv z{bO8|qC-6_s+2{aF@~Vt@jHV&b?VPB1)U<;J5eS%F$75#%Ll)HZ>SXOI$<<~jOP{?3hFJ){*+ zm%gCm(krpwH}OX8^dY%Wusv(ZAbdNB9^-Yya`TviNSb>6Qmm{BOLnmUq$!Dt(Tv(< z7A-;9%DcWvvw`SqL#eBG1>j^ofle1#XE4tiaw{7-O|udf8dlU2XF|H=9y?XJ*=hB# zeV1fVI49+YQYNG_*s7=7R+$$2G5VXw1c8$ah>%m}@WE3h7m(AE%uNKU)OXifHi_wY zWR<|Z3BPQnUJ@A0P!~=Oc4^p?^$4;IDMH*7vwg){CxQxWFDTu0s#zS_+|NHb&#Z+(%%P)}g?kr+qGpjPx~=?}K;*4G(@JkMTiB$Fqc5VzPXNgH%>o zBiM&Ao?72AJIxN9nl8VI_3|6GL_VUPF5xbx1BnR;Q`&ASo{Ucqr$2PmM3}hatVk~P z(iQBr>fT+#mu>8~+`Hn4jpp!lp2HNmD&Mg`p}kYyxJ#Ri77dsp_1b$pX@3Tyjktxz zIV_MBLKwJ0#5$MjehpsZy**|=a98iVUi9cqc7bKYtxwZ^$a0yl5|`^Bx`TatksPWD z4hv@>;OYhaeI!WU?CfElh=uQ+VB#ohc6bdDy3EeY36`ml*%i%CH#c673`#lO420}k z=B>R_X5tHOH%|Bw$noB1ECsF~1qSEAuobyh7)iJ#>2J4s;fjmtiv@zJfN#;ATy&k$(hdaTTXK+8>%hH$bp z5w;)i6{9o87xH#a+i41)?Bd?O+wuBB_RUe#f>d23FDbm zM|1?=NclGo~&L zSL?FKcKcRWVO*4*022&d#!bob$li2@HX-rx)GUE{`fqdN_%Xxw8#*rZRbunNsPN#4 zFDtIhtWb}{PG-9kYTlY;r(Qb>6a~oOd(-A{bgIze8@A(PrkhgI-nVh?*5Tf$c4}xz z?eXtA2^cFSMt#UFiUxaVtvE;#yM*|B$Im3Hs%NKz)^myp`*nos(GJa(hf_?^W-VzB zmkmmO&K)qXz@rPM?Px6N#$|aQ$C+&P1sXQXR=_2bomo7AsxM#5f8y4z<0yp-X%Y~sGvCS?hJd8^|5 zJDI)e>}qxkRKe;q67!d5$XCn5TLi{N@WuX^WBlJN4~!SfLql|b6?WfltfoFjA9OZLz9EO< z#{H5AP5oFn-j#d&{>LoAvM1Q9QcD0^{irW-+ACnMN(BK$2mI%6o4lHQf0aMKbn>rU z|M~%wzc>_LPG6JyUroY4x&E|Ce^0=C&FufHSVR1Cp8vmc{vNpgnxOetS%10wEnV|Z z#{U%8{ukp0=6{ZI|5ud1xB!4xZ|JXb&i?Pl|G)W0|E%%9m;r!S@93|>!13>3zxzu6 zEsojW;Qa18{kJ$-e}nV8FZG{sUcITm%G}@JynN5%H{a?%Bfa`be-%{Df7j4ozSe(> zBK|ihfB9bjEsEFQp#0^F{ekl5lmFU-KOL%9Z|tv9`!^{6!8iN!sr(c4_qp=b7yGNg uasBR@{VU(^)4}UZ`d0~jN#FR}c~xEt;w5n!06>2EV|)2%(Sq>n)&B$N(k(dv literal 0 HcmV?d00001 diff --git a/manage.py b/manage.py new file mode 100644 index 0000000..d28f1e9 --- /dev/null +++ b/manage.py @@ -0,0 +1,10 @@ +#!/usr/bin/env python +import os +import sys + +if __name__ == "__main__": + os.environ.setdefault("DJANGO_SETTINGS_MODULE", "common.settings") + + from django.core.management import execute_from_command_line + + execute_from_command_line(sys.argv) diff --git a/stages/__init__.py b/stages/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/stages/admin.py b/stages/admin.py new file mode 100644 index 0000000..c52e445 --- /dev/null +++ b/stages/admin.py @@ -0,0 +1,46 @@ +from django.contrib import admin + +from stages.models import (Student, Section, Referent, Corporation, CorpContact, + Domain, Period, Availability, Training) + + +class StudentAdmin(admin.ModelAdmin): + list_display = ('__unicode__', 'pcode', 'city', 'section') + list_filter = ('section',) + fields = (('last_name', 'first_name'), ('pcode', 'city'), + 'birth_date', 'section') + + +class CorpContactAdmin(admin.ModelAdmin): + list_display = ('__unicode__', 'corporation') + fields = ('corporation', ('last_name', 'first_name'), ('tel', 'email')) + +class ContactInline(admin.TabularInline): + model = CorpContact + extra = 1 + +class CorporationAdmin(admin.ModelAdmin): + list_display = ('name', 'pcode', 'city') + fields = ('name', 'street', ('pcode', 'city'), ('tel', 'email')) + inlines = [ContactInline] + + +class PeriodAdmin(admin.ModelAdmin): + list_display = ('dates', 'section') + list_filter = ('section',) + + +class AvailabilityAdmin(admin.ModelAdmin): + list_display = ('corporation', 'period', 'number') + fields = (('corporation', 'period'), ('number', 'domain')) + + +admin.site.register(Student, StudentAdmin) +admin.site.register(Section) +admin.site.register(Referent) +admin.site.register(Corporation, CorporationAdmin) +admin.site.register(CorpContact, CorpContactAdmin) +admin.site.register(Domain) +admin.site.register(Period, PeriodAdmin) +admin.site.register(Availability, AvailabilityAdmin) +admin.site.register(Training) diff --git a/stages/fixtures/test_fixture.json b/stages/fixtures/test_fixture.json new file mode 100644 index 0000000..b2a8745 --- /dev/null +++ b/stages/fixtures/test_fixture.json @@ -0,0 +1,125 @@ +[ + { + "pk": 1, + "model": "stages.section", + "fields": { + "name": "ASE" + } + }, + { + "pk": 2, + "model": "stages.section", + "fields": { + "name": "ASSC" + } + }, + { + "pk": 3, + "model": "stages.section", + "fields": { + "name": "EDE" + } + }, + { + "pk": 1, + "model": "stages.student", + "fields": { + "birth_date": "1994-05-12", + "first_name": "Albin", + "last_name": "Dupond", + "section": 1, + "pcode": "2300", + "city": "La Chaux-de-Fonds" + } + }, + { + "pk": 2, + "model": "stages.student", + "fields": { + "birth_date": "1994-07-12", + "first_name": "Justine", + "last_name": "Varrin", + "section": 1, + "pcode": "2000", + "city": "Neuchâtel" + } + }, + { + "pk": 3, + "model": "stages.student", + "fields": { + "birth_date": "1994-05-20", + "first_name": "Elvire", + "last_name": "Hickx", + "section": 1, + "pcode": "2053", + "city": "Cernier" + } + }, + { + "pk": 4, + "model": "stages.student", + "fields": { + "birth_date": "1994-10-11", + "first_name": "André", + "last_name": "Allemand", + "section": 1, + "pcode": "2314", + "city": "La Sagne" + } + }, + { + "pk": 1, + "model": "stages.referent", + "fields": { + "first_name": "Julie", + "last_name": "Caux" + } + }, + { + "pk": 1, + "model": "stages.corporation", + "fields": { + "city": "Moulineaux", + "tel": "", + "name": "Centre p\u00e9dagogique XY", + "pcode": "2500", + "street": "Rue des champs 12", + "email": "" + } + }, + { + "pk": 1, + "model": "stages.domain", + "fields": { + "name": "handicap" + } + }, + { + "pk": 2, + "model": "stages.domain", + "fields": { + "name": "petite enfance" + } + }, + { + "pk": 1, + "model": "stages.period", + "fields": { + "section": 1, + "start_date": "2012-11-26", + "end_date": "2012-12-07" + } + }, + { + "pk": 1, + "model": "stages.training", + "fields": { + "corporation": 1, + "domain": 1, + "period": 1, + "student": 1, + "referent": 1 + } + } +] diff --git a/stages/forms.py b/stages/forms.py new file mode 100644 index 0000000..57cd624 --- /dev/null +++ b/stages/forms.py @@ -0,0 +1,12 @@ +from django import forms + +from .models import Section, Period + + +class PeriodForm(forms.Form): + section = forms.ModelChoiceField(queryset=Section.objects.all()) + period = forms.ModelChoiceField(queryset=None) + + def __init__(self, data, *args, **kwargs): + pass + diff --git a/stages/models.py b/stages/models.py new file mode 100644 index 0000000..578c4be --- /dev/null +++ b/stages/models.py @@ -0,0 +1,126 @@ +# -*- encoding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models + + +class Section(models.Model): + """ Filières """ + name = models.CharField(max_length=20) + + class Meta: + verbose_name = "Filière" + + def __unicode__(self): + return self.name + + +class Student(models.Model): + first_name = models.CharField(max_length=40, verbose_name='Prénom') + last_name = models.CharField(max_length=40, verbose_name='Nom') + birth_date = models.DateField(verbose_name='Date de naissance') + pcode = models.CharField(max_length=4, verbose_name='Code postal') + city = models.CharField(max_length=40, verbose_name='Localité') + section = models.ForeignKey(Section) + + class Meta: + verbose_name = "Étudiant" + + def __unicode__(self): + return '%s %s' % (self.last_name, self.first_name) + + +class Referent(models.Model): + first_name = models.CharField(max_length=40, verbose_name='Prénom') + last_name = models.CharField(max_length=40, verbose_name='Nom') + + class Meta: + verbose_name = "Référent" + + def __unicode__(self): + return '%s %s' % (self.last_name, self.first_name) + + +class Corporation(models.Model): + name = models.CharField(max_length=100, verbose_name='Nom') + street = models.CharField(max_length=100, verbose_name='Rue') + pcode = models.CharField(max_length=4, verbose_name='Code postal') + city = models.CharField(max_length=40, verbose_name='Localité') + tel = models.CharField(max_length=20, blank=True, verbose_name='Téléphone') + email = models.CharField(max_length=40, blank=True, verbose_name='Courriel') + + class Meta: + verbose_name = "Institution" + + def __unicode__(self): + return self.name + + +class CorpContact(models.Model): + corporation = models.ForeignKey(Corporation, verbose_name='Institution') + first_name = models.CharField(max_length=40, verbose_name='Prénom') + last_name = models.CharField(max_length=40, verbose_name='Nom') + tel = models.CharField(max_length=20, blank=True, verbose_name='Téléphone') + email = models.CharField(max_length=40, blank=True, verbose_name='Courriel') + + class Meta: + verbose_name = "Contact" + + def __unicode__(self): + return '%s %s' % (self.last_name, self.first_name) + + +class Domain(models.Model): + name = models.CharField(max_length=50, verbose_name='Nom') + + class Meta: + verbose_name = "Domaine" + + def __unicode__(self): + return self.name + + +class Period(models.Model): + """ Périodes de stages """ + section = models.ForeignKey(Section, verbose_name='Filière') + start_date = models.DateField(verbose_name='Date de début') + end_date = models.DateField(verbose_name='Date de fin') + + class Meta: + verbose_name = "Période de stage" + + def __unicode__(self): + return '%s (filière %s)' % (self.dates, self.section) + + @property + def dates(self): + return '%s - %s' % (self.start_date, self.end_date) + + +class Availability(models.Model): + """ Disponibilités des institutions """ + corporation = models.ForeignKey(Corporation, verbose_name='Institution') + period = models.ForeignKey(Period, verbose_name='Période') + number = models.IntegerField(verbose_name='Nombre de places') + domain = models.ForeignKey(Domain, verbose_name='Domaine') + + class Meta: + verbose_name = "Disponibilité" + + def __unicode__(self): + return '%d place(s) chez %s (%s)' % (self.number, self.corporation, self.period) + + +class Training(models.Model): + """ Stages """ + student = models.ForeignKey(Student, verbose_name='Étudiant') + corporation = models.ForeignKey(Corporation, verbose_name='Institution') + referent = models.ForeignKey(Referent, verbose_name='Référent') + period = models.ForeignKey(Period, verbose_name='Période') + domain = models.ForeignKey(Domain, verbose_name='Domaine') + + class Meta: + verbose_name = "Stage" + + def __unicode__(self): + return '%s chez %s (%s)' % (self.student, self.corporation, self.period) diff --git a/stages/views.py b/stages/views.py new file mode 100644 index 0000000..9f21fa9 --- /dev/null +++ b/stages/views.py @@ -0,0 +1,67 @@ +import json + +from django.http import HttpResponse, HttpResponseNotAllowed +from django.shortcuts import get_object_or_404 +from django.views.decorators.csrf import csrf_exempt +from django.views.generic import DetailView, TemplateView + +from .forms import PeriodForm +from .models import Section, Student, Corporation, Period, Training + + +class StudentSummaryView(DetailView): + model = Student + template_name = 'student_summary.html' + + +class CorporationSummaryView(DetailView): + model = Corporation + template_name = 'corporation_summary.html' + + +class AttributionView(TemplateView): + template_name = 'attribution.html' + + def get_context_data(self, **kwargs): + context = super(AttributionView, self).get_context_data(**kwargs) + context.update({ + #'period_form': PeriodForm(), + 'sections': Section.objects.all(), + }) + return context + +# AJAX views: + +def section_periods(request, pk): + """ Return all periods from a section (JSON) """ + section = get_object_or_404(Section, pk=pk) + periods = [(p.id, p.dates) for p in section.period_set.all()] + return HttpResponse(json.dumps(periods), content_type="application/json") + +def period_students(request, pk): + """ Return all students from period's section, with corresponding Training + if existing (JSON) + """ + period = get_object_or_404(Period, pk=pk) + students = period.section.student_set.all().order_by('last_name') + trainings = dict((t.student_id, t.id) for t in Training.objects.filter(period=period)) + data = [{'name': unicode(s), 'id': s.id, 'training_id': trainings.get(s.id)} for s in students] + return HttpResponse(json.dumps(data), content_type="application/json") + +def period_corporations(request, pk): + """ Return all corporations with availabilities in the specified period """ + period = get_object_or_404(Period, pk=pk) + corps = [(av.corporation.id, av.corporation.name) + for av in period.availability_set.select_related('corporation').all()] + return HttpResponse(json.dumps(corps), content_type="application/json") + +@csrf_exempt +def new_training(request): + if request.method != 'POST': + return HttpResponseNotAllowed() + training = Training.objects.create( + period=Period.objects.get(pk=request.POST.get('period')), + student=Student.objects.get(pk=request.POST.get('student')), + corporation=Corporation.objects.get(pk=request.POST.get('corp')) + ) + return HttpResponse('OK') diff --git a/templates/admin/base_site.html b/templates/admin/base_site.html new file mode 100644 index 0000000..efeca77 --- /dev/null +++ b/templates/admin/base_site.html @@ -0,0 +1,10 @@ +{% extends "admin/base.html" %} +{% load i18n %} + +{% block title %}{{ title }} | {% trans 'Gestion stages' %}{% endblock %} + +{% block branding %} +

École Pierre-Coullery
Gestion des stages

+{% endblock %} + +{% block nav-global %}{% endblock %} diff --git a/templates/attribution.html b/templates/attribution.html new file mode 100644 index 0000000..39bff09 --- /dev/null +++ b/templates/attribution.html @@ -0,0 +1,137 @@ +{% extends "admin/base_site.html" %} +{% load admin_static %} + +{% block extrastyle %} + +{% endblock %} + +{% block extrahead %} + + +{% endblock %} + +{% block content %} +
+
+ + + + +
+
+ +
+
+ +
+
+ +
+
+ +
+
+ +
+
+
+
+
+{% endblock %} diff --git a/templates/corporation_summary.html b/templates/corporation_summary.html new file mode 100644 index 0000000..554c673 --- /dev/null +++ b/templates/corporation_summary.html @@ -0,0 +1,5 @@ +{{ object.name }}
+{{ object.street }}
+{{ object.pcode }} {{ object.city }}
+Tél: {{ object.tel }}
+Courriel: {{ object.courriel }} diff --git a/templates/student_summary.html b/templates/student_summary.html new file mode 100644 index 0000000..1b8dea1 --- /dev/null +++ b/templates/student_summary.html @@ -0,0 +1,3 @@ +{{ object.first_name }} {{ object.last_name }}
+{{ object.pcode }} {{ object.city }}
+Date de naissance: {{ object.birth_date }}