Initial import
This commit is contained in:
commit
2d5451f982
|
@ -0,0 +1,664 @@
|
|||
Core of Mandaye is entirely under the copyrigh of Entr'ouvert and distributed
|
||||
under the license AGPLv3.
|
||||
|
||||
GNU AFFERO GENERAL PUBLIC LICENSE
|
||||
Version 3, 19 November 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 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.
|
||||
|
||||
<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 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 <http://www.gnu.org/licenses/>.
|
||||
|
||||
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
|
||||
<http://www.gnu.org/licenses/>.
|
|
@ -0,0 +1,2 @@
|
|||
include COPYING MANIFEST VERSION
|
||||
recursive-include mandaye_vincennes/templates *.html
|
|
@ -0,0 +1 @@
|
|||
VERSION="0.1"
|
|
@ -0,0 +1,62 @@
|
|||
|
||||
import urllib
|
||||
import socket
|
||||
import ssl
|
||||
|
||||
from mandaye_vincennes.auth.vincennes import VincennesAuth
|
||||
from mandaye.http import HTTPRequest
|
||||
from mandaye.response import _500, _302, _401
|
||||
from mandaye.server import get_response
|
||||
|
||||
class EspaceFamilleAuth(VincennesAuth):
|
||||
|
||||
def replay(self, env, post_values):
|
||||
""" This hack a hack method
|
||||
There is a bug in httplib so this method make a manual post
|
||||
"""
|
||||
if not "://" in self.form_url:
|
||||
self.form_url = env['target'].geturl() + '/' + self.form_url
|
||||
request = HTTPRequest()
|
||||
login = get_response(env, request, self.form_url)
|
||||
if login.code == 502:
|
||||
return login
|
||||
try:
|
||||
fsession = login.cookies['JSESSIONID'].value
|
||||
except Exception, e:
|
||||
return _500('Espace famille: no cookie JSESSIONID', e)
|
||||
|
||||
post_values['idSession'] = fsession
|
||||
body = urllib.urlencode(post_values)
|
||||
headers = "POST %s HTTP/1.1\r\nAccept-Encoding: identity\r\n\
|
||||
Content-Length: %d\r\nConnection: close\r\n\
|
||||
Accept: text/html; */*\r\nHost: %s\r\n\
|
||||
Cookie: %s\r\nContent-Type: application/x-www-form-urlencoded\r\n\r\n" % (
|
||||
self.form_values['form_action'], len(body), env['target'].netloc,
|
||||
login.cookies.output(attrs=[], sep=';', header=''))
|
||||
|
||||
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||
ssl_sock = ssl.wrap_socket(s)
|
||||
# TODO: don't force the port
|
||||
ssl_sock.connect((env['target'].netloc, 443))
|
||||
# Set a simple HTTP request -- use httplib in actual code.
|
||||
ssl_sock.write(headers)
|
||||
ssl_sock.write(body)
|
||||
# Read a chunk of data. Will not necessarily
|
||||
# read all the data returned by the server.
|
||||
data = ssl_sock.read()
|
||||
# note that closing the SSLSocket will also close the underlying socket
|
||||
ssl_sock.close()
|
||||
data = data.split('\r\n')
|
||||
line1 = data[0].split(' ')
|
||||
code = line1[1]
|
||||
if code == '302':
|
||||
del data[0]
|
||||
for header in data:
|
||||
header = header.split(':', 1)
|
||||
if header[0].lower() == 'location':
|
||||
location = header[1].replace(' ', '')
|
||||
location = location.replace(env['target'].geturl(),
|
||||
"%s://%s" % (env['mandaye.scheme'], env["HTTP_HOST"]))
|
||||
return _302(location, login.cookies)
|
||||
return _401('Login failed')
|
||||
|
|
@ -0,0 +1,143 @@
|
|||
""" Vincennes authentifications
|
||||
"""
|
||||
|
||||
# TODO : port this code to support the new sql backend
|
||||
|
||||
import base64
|
||||
import traceback
|
||||
|
||||
from Crypto.Cipher import AES
|
||||
from datetime import datetime, timedelta
|
||||
from urlparse import parse_qs
|
||||
|
||||
from mandaye.auth.authform import AuthForm
|
||||
from mandaye.log import logger
|
||||
from mandaye.models import Site, ExtUser, LocalUser
|
||||
from mandaye.db import sql_session
|
||||
from mandaye.response import _502, _302
|
||||
from mandaye.server import get_response
|
||||
|
||||
class VincennesAuth(AuthForm):
|
||||
""" Specific authentification class for Vincennes
|
||||
"""
|
||||
|
||||
def __init__(self, form_values, site_name, url):
|
||||
""" url: Vincennes 'idp' url
|
||||
"""
|
||||
self.url = url
|
||||
AuthForm.__init__(self, form_values, site_name)
|
||||
|
||||
def _parse_qs(self, query):
|
||||
""" Parse query string
|
||||
Return a dict
|
||||
"""
|
||||
res = {}
|
||||
values = query.split('&')
|
||||
for value in values:
|
||||
keyvalue = value.split('=', 1)
|
||||
if len(keyvalue) < 2:
|
||||
res[keyvalue[0]] = ''
|
||||
else:
|
||||
res[keyvalue[0]] = keyvalue[1]
|
||||
return res
|
||||
|
||||
def get_current_unique_id(self, env):
|
||||
""" Return the current Vincennes unique id
|
||||
"""
|
||||
from mandaye import config
|
||||
# TODO: test time validity
|
||||
if not env['QUERY_STRING']:
|
||||
return None
|
||||
query = self._parse_qs(env['QUERY_STRING'])
|
||||
if query.has_key('token'):
|
||||
try:
|
||||
token = query['token']
|
||||
token = base64.b64decode(token)
|
||||
cipher = AES.new(config.secret, AES.MODE_CFB, "0000000000000000")
|
||||
decode = cipher.decrypt(token)
|
||||
if not decode:
|
||||
raise "Empty token"
|
||||
except Exception, e:
|
||||
if config.debug:
|
||||
traceback.print_exc()
|
||||
logger.info("Invalid token %s" % e)
|
||||
return None
|
||||
else:
|
||||
info = eval(decode[16:])
|
||||
if info.has_key('date'):
|
||||
date = info['date']
|
||||
token_date = datetime.strptime(date[:-6], '%Y-%m-%dT%H:%M:%S')
|
||||
delta = datetime.utcnow() - token_date
|
||||
timeout = timedelta(seconds=config.token_timeout)
|
||||
if abs(delta) > timeout:
|
||||
logger.warning('Vincennes token timeout (delta of %s seconds)' \
|
||||
% abs(delta))
|
||||
return None
|
||||
return info['pseudo']
|
||||
return None
|
||||
|
||||
def connection(self, env, values, request, response):
|
||||
""" Connection to the compte citoyen
|
||||
"""
|
||||
dest_url = "%s://%s%s" % (env['mandaye.scheme'], env['HTTP_HOST'],
|
||||
values.get('next_url'))
|
||||
location = "%s?next_url=%s&service=%s" % \
|
||||
(self.url, dest_url, self.site_name)
|
||||
return _302(location)
|
||||
|
||||
def auto_login(self, env, values, condition, request, response):
|
||||
""" Try to auto login the user if he is already login on www.vincennes.fr
|
||||
"""
|
||||
logger.debug('Trying to auto log user on %s' % self.site_name)
|
||||
env['beaker.session']['auto_login'] = True
|
||||
env['beaker.session'].save()
|
||||
login = self.get_current_login(env)
|
||||
if env['beaker.session'].has_key('next_url'):
|
||||
path = env['beaker.session']['next_url']
|
||||
else:
|
||||
logger.warning('Auto login without mandaye_next_url automatically redirect to /')
|
||||
path = '/'
|
||||
if not login:
|
||||
logger.debug('Auto login failed because the user is not connected on vincennes.fr')
|
||||
return _302(path, request.cookies)
|
||||
env['beaker.session']['unique_id'] = unique_id
|
||||
env['beaker.session'].save()
|
||||
ext_user = sql_session().query(ExtUser).\
|
||||
join(LocalUser).\
|
||||
join(Site).\
|
||||
filter(LocalUser.login==login).\
|
||||
filter(Site.name==self.site_name).\
|
||||
order_by(ExtUser.last_connection.desc()).\
|
||||
first()
|
||||
if not ext_user:
|
||||
logger.debug("No association found redirect to the association page %s" % values.get('associate_url'))
|
||||
# TODO: urllencode path
|
||||
return _302(values.get('associate_url') + "?type=first&next_url=%s" % path)
|
||||
else:
|
||||
response = self._login_ext_user(ext_user, env, condition, values)
|
||||
logger.info("User %s has been successfully auto login on %s" % (login, self.site_name))
|
||||
return _302(path, response.cookies)
|
||||
|
||||
def auto_connection(self, env, values, request, response):
|
||||
""" Try to auto connect a user on www.vincennes.fr
|
||||
This method will try to auto connect only if the referer match and
|
||||
if the request is a get and the user isn't login into Mandaye
|
||||
"""
|
||||
referer = request.headers.getheader('referer')
|
||||
if not env['beaker.session'].get(self.site_name) \
|
||||
and not env['beaker.session'].get('auto_login'):
|
||||
if (not referer and values.get('empty_referer')) or \
|
||||
(referer and values.get('autologin_from') in referer):
|
||||
dest_url = "%s://%s%s" % (env['mandaye.scheme'], env['HTTP_HOST'],
|
||||
values.get('next_url'))
|
||||
target = "%s?service=%s&pass=1&next_url=%s" % \
|
||||
(self.url, self.site_name, dest_url)
|
||||
if env['QUERY_STRING']:
|
||||
env['beaker.session']['next_url'] = env['PATH_INFO'] + "?%s" % env['QUERY_STRING']
|
||||
else:
|
||||
env['beaker.session']['next_url'] = env['PATH_INFO']
|
||||
env['beaker.session'].save()
|
||||
logger.debug('Auto connection call %s' % target)
|
||||
return _302(target)
|
||||
return response
|
||||
|
|
@ -0,0 +1,90 @@
|
|||
|
||||
import logging
|
||||
import os
|
||||
|
||||
_PROJECT_PATH = os.path.join(os.path.dirname(__file__), '..')
|
||||
|
||||
## Virtual hosts configuration
|
||||
hosts = {
|
||||
'linuxfr.local:8000': [
|
||||
{'path': r'/',
|
||||
'target': 'http://linuxfr.org',
|
||||
'mapping': 'mandaye.configs.linuxfr_saml_example.linuxfr_mapping'
|
||||
},
|
||||
],
|
||||
}
|
||||
|
||||
## SQL Backend config
|
||||
# Database configuration
|
||||
# http://docs.sqlalchemy.org/en/rel_0_7/core/engines.html
|
||||
# rfc 1738 https://tools.ietf.org/html/rfc1738
|
||||
# dialect+driver://username:password@host:port/database
|
||||
db_url = 'sqlite:///' + os.path.join(_PROJECT_PATH, 'test.db')
|
||||
|
||||
## Log configuration
|
||||
debug = False
|
||||
syslog = False
|
||||
log_file = os.path.join(_PROJECT_PATH, 'mandaye_vincennes/mandaye_mandaye_vincennes.log')
|
||||
log_level = logging.INFO
|
||||
# Log rotation
|
||||
# W[0-6] : weekly (0: Monday), D: day, ... (python doc)
|
||||
log_when = 'W6'
|
||||
# Every week
|
||||
log_interval = 1
|
||||
# BackupCount (keep one year of log)
|
||||
log_backup = 52
|
||||
|
||||
## PATH
|
||||
# Template directory
|
||||
template_directory = os.path.join(_PROJECT_PATH, 'mandaye_vincennes/templates')
|
||||
# Static url
|
||||
static_url = '/static'
|
||||
# Static folder
|
||||
static_root = os.path.join(_PROJECT_PATH, 'mandaye_vincennes/static')
|
||||
# Data dir
|
||||
data_dir = os.path.join(_PROJECT_PATH, 'data')
|
||||
|
||||
# Email notification configuration
|
||||
email_notification = False
|
||||
smtp_host = 'localhost'
|
||||
smtp_port = 25
|
||||
email_from = 'traceback@entrouvert.com'
|
||||
email_to = ['admin@localhost']
|
||||
|
||||
# Use long traceback with xtraceback
|
||||
use_long_trace = True
|
||||
|
||||
# Ask Mandaye to auto decompress a response message
|
||||
# Decompress response only if you load a filter
|
||||
auto_decompress = True
|
||||
|
||||
# Encrypt service provider passwords with a secret
|
||||
# You should install pycypto to use this feature
|
||||
encrypt_sp_password = False
|
||||
# Must be a 16, 24, or 32 bytes long
|
||||
encrypt_secret = ''
|
||||
|
||||
# Beaker session configuration
|
||||
session_opts = {
|
||||
'session.type': 'file',
|
||||
'session.cookie_expires': True,
|
||||
'session.timeout': 3600,
|
||||
'session.data_dir': '/var/tmp/beaker'
|
||||
}
|
||||
|
||||
# Choose storage
|
||||
# Only mandaye.backends.sql at the moment
|
||||
storage_backend = "mandaye.backends.sql"
|
||||
|
||||
# Needed if ssl is activated
|
||||
ssl = False
|
||||
keyfile = ''
|
||||
certfile = ''
|
||||
|
||||
# Import local config
|
||||
try:
|
||||
from mandaye_vincennes.local_config import *
|
||||
except ImportError, e:
|
||||
if not 'local_config' in e.args[0]:
|
||||
raise ImproperlyConfigured('Error while importing "local_config.py"')
|
||||
|
|
@ -0,0 +1,154 @@
|
|||
|
||||
from mandaye_vincennes.auth.vincennes import VincennesAuth
|
||||
from mandaye_vincennes.filters import vincennes
|
||||
|
||||
form_values = {
|
||||
'login_url': '/sezhame/page/connexion-abonne',
|
||||
'form_attrs': { 'id': 'dk-opac15-login-form', },
|
||||
'post_fields': ['user', 'password'],
|
||||
'username_field': 'user',
|
||||
'password_field': 'password',
|
||||
}
|
||||
|
||||
auth = VincennesAuth(form_values, 'biblio', 'https://www.vincennes.fr/comptecitoyen/auth')
|
||||
filters = vincennes.Biblio()
|
||||
|
||||
biblio_mapping = [
|
||||
{
|
||||
'path': r'/(?!/*mandaye)',
|
||||
'on_response': [
|
||||
{
|
||||
'filter': filters.resp_html,
|
||||
'content-types': ['application/x-javascript', 'text/html', 'text/css'],
|
||||
},
|
||||
{
|
||||
'filter': auth.auto_connection,
|
||||
'values': {
|
||||
'next_url': '/mandaye/auto_login',
|
||||
'empty_referer': True,
|
||||
'autologin_from': 'www.vincennes.fr'
|
||||
}
|
||||
}],
|
||||
},
|
||||
{
|
||||
'path': r'/sezhame',
|
||||
'on_response': [{
|
||||
'filter': filters.resp_multicompte_html,
|
||||
'content-types': ['text/html'],
|
||||
'values': {
|
||||
'associate_url': '/mandaye/associate',
|
||||
'template': 'biblio/multicompte.html',
|
||||
'nosso_template': 'biblio/nosso.html',
|
||||
'site_name': 'biblio'
|
||||
},
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/auto_login$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.auto_login,
|
||||
'values': {
|
||||
'associate_url': '/mandaye/associate',
|
||||
},
|
||||
'condition': 'response.code==302',
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/login$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.login,
|
||||
'values': {
|
||||
'associate_url': '/mandaye/associate',
|
||||
},
|
||||
'condition': 'response.code==302',
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/associate$',
|
||||
'method': 'GET',
|
||||
'target': '/sezhame/page/connexion-abonne',
|
||||
'on_response': [{
|
||||
'filter': filters.resp_associate_login,
|
||||
'values': {
|
||||
'action': '/mandaye/associate',
|
||||
'template': 'biblio/associate.html',
|
||||
'badlogin_msg': "Numéro de carte ou/et mot de passe incorrects",
|
||||
'failed_msg': "Vos identifiants pour la bibliothèque ne fonctionnent plus ! Merci de les ressaisir.",
|
||||
},
|
||||
},
|
||||
{
|
||||
'filter': filters.resp_multicompte_html,
|
||||
'values': {
|
||||
'associate_url': '/mandaye/associate',
|
||||
'template': 'biblio/multicompte.html',
|
||||
'nosso_template': 'biblio/nosso.html',
|
||||
'site_name': 'biblio'
|
||||
},
|
||||
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/associate$',
|
||||
'method': 'POST',
|
||||
'response': [
|
||||
{
|
||||
'filter': auth.associate_submit,
|
||||
'values': {
|
||||
'connection_url': '/mandaye/connection',
|
||||
'associate_url': '/mandaye/associate',
|
||||
},
|
||||
'condition': "response.code==302"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/connection$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.connection,
|
||||
'values': {
|
||||
'next_url': '/mandaye/login',
|
||||
}
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/sezhame/page/connexion-abonne$',
|
||||
'method': 'GET',
|
||||
'on_response': [{
|
||||
'filter': filters.resp_html_login_page,
|
||||
'values': {
|
||||
'connection_url': '/mandaye/connection',
|
||||
'template': 'biblio/login.html',
|
||||
'title': 'Connexion via votre compte citoyen'
|
||||
}
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/change_user$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.change_user,
|
||||
'values': {
|
||||
'associate_url': '/mandaye/associate',
|
||||
},
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/disassociate$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.disassociate,
|
||||
'values': {
|
||||
'next_url': '/sezhame',
|
||||
},
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/sezhame/logout$',
|
||||
'on_response': [{'filter': auth.logout}]
|
||||
},
|
||||
]
|
||||
|
||||
|
|
@ -0,0 +1,153 @@
|
|||
|
||||
from mandaye_vincennes.auth.vincennes import VincennesAuth
|
||||
from mandaye_vincennes.filters.vincennes import Duonet
|
||||
|
||||
|
||||
filters = Duonet()
|
||||
duonet_key = 'CV4j27Em0dM%3d'
|
||||
|
||||
form_values = {
|
||||
'login_url': 'Connect.aspx?key=%s' % duonet_key,
|
||||
'form_attrs': { 'name': 'form1' },
|
||||
'post_fields': ['txtNomFoyer', 'txtDateNaissance', 'txtCode'],
|
||||
'username_field': 'txtNomFoyer',
|
||||
'password_field': 'txtCode'
|
||||
}
|
||||
|
||||
|
||||
auth = VincennesAuth(form_values, 'duonet', 'https://www.vincennes.fr/comptecitoyen/auth')
|
||||
|
||||
duonet_mapping = [
|
||||
{
|
||||
'path': r'/',
|
||||
'on_response': [
|
||||
{
|
||||
'content-types': ['text/html'],
|
||||
'filter': filters.resp_global_html,
|
||||
'values': {
|
||||
'associate_url': '/associate',
|
||||
'nosso_template': 'duonet/nosso.html',
|
||||
'site_name': 'duonet'
|
||||
},
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
'path': r'/Default.aspx$',
|
||||
'on_response': [
|
||||
{
|
||||
'filter': auth.auto_connection,
|
||||
'values': {
|
||||
'next_url': '/mandaye/auto_login',
|
||||
'autologin_from': 'www.vincennes.fr'
|
||||
}
|
||||
},
|
||||
]
|
||||
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/auto_login$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.auto_login,
|
||||
'values': {
|
||||
'associate_url': '/associate',
|
||||
},
|
||||
'condition': 'response.code==302',
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/logout$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': filters.logout,
|
||||
'values': {
|
||||
'index_url': '/Connect.aspx?key=%s' % duonet_key,
|
||||
},
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/vincennes/login$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.login,
|
||||
'values': {
|
||||
'associate_url': '/associate',
|
||||
},
|
||||
'condition': 'response.code==302',
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/associate$',
|
||||
'method': 'GET',
|
||||
'target': '/Connect.aspx?key=%s' % duonet_key,
|
||||
'on_response': [{
|
||||
'filter': filters.resp_associate,
|
||||
'values': {
|
||||
'action': '/associate',
|
||||
'template': 'duonet/associate.html',
|
||||
'badlogin_msg': "Mauvais identifiants",
|
||||
'failed_msg': "Vos identifiants pour le conservatoire ne fonctionnent plus ! Merci de les ressaisir.",
|
||||
},
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/associate$',
|
||||
'method': 'POST',
|
||||
'response': [
|
||||
{
|
||||
'filter': auth.associate_submit,
|
||||
'values': {
|
||||
'connection_url': '/mandaye/connection',
|
||||
'associate_url': '/associate',
|
||||
},
|
||||
'condition': "response.code==302"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/connection$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.connection,
|
||||
'values': {
|
||||
'next_url': '/vincennes/login',
|
||||
}
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/disassociate$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.disassociate,
|
||||
'values': {
|
||||
'next_url': '/Default.aspx',
|
||||
},
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/Connect.aspx$',
|
||||
'method': 'GET',
|
||||
'on_response': [{
|
||||
'filter': filters.resp_login_page,
|
||||
'values': {
|
||||
'connection_url': '/mandaye/connection',
|
||||
'template': 'duonet/login.html',
|
||||
}
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'/$',
|
||||
'method': 'GET',
|
||||
'target': '/Connect.aspx?key=%s' % duonet_key,
|
||||
'on_response': [{
|
||||
'filter': filters.resp_login_page,
|
||||
'values': {
|
||||
'connection_url': '/mandaye/connection',
|
||||
'template': 'duonet/login.html',
|
||||
}
|
||||
}]
|
||||
},
|
||||
]
|
||||
|
||||
|
|
@ -0,0 +1,135 @@
|
|||
|
||||
from mandaye_vincennes.auth.espacefamille import EspaceFamilleAuth
|
||||
from mandaye_vincennes.filters.vincennes import EspaceFamille
|
||||
|
||||
folder_target = '/vincennes-noredirect'
|
||||
filters = EspaceFamille()
|
||||
|
||||
form_values = {
|
||||
'post_url': '%s/login.do' % folder_target,
|
||||
'login_url': '%s/index.do' % folder_target,
|
||||
'form_attrs': { 'action': 'login.do', },
|
||||
'post_fields': ['codeFamille', 'motDePasse'],
|
||||
'username_field': 'codeFamille',
|
||||
'password_field': 'motDePasse'
|
||||
}
|
||||
|
||||
auth = EspaceFamilleAuth(form_values, 'espace_famille', 'https://www.vincennes.fr/comptecitoyen/auth')
|
||||
|
||||
famille_mapping = [
|
||||
{
|
||||
'path': r'/$',
|
||||
'method': 'GET',
|
||||
'redirect': '%s/index.do' % folder_target
|
||||
},
|
||||
{
|
||||
'path': r'/(?!/*mandaye|.*/associate)',
|
||||
'method': 'GET',
|
||||
'on_response': [
|
||||
{
|
||||
'filter': filters.resp_disassociate,
|
||||
'content-types': ['text/html'],
|
||||
'values': {'site_name': 'espace_famille'}
|
||||
},
|
||||
{
|
||||
'filter': auth.auto_connection,
|
||||
'content-types': ['text/html'],
|
||||
'values': {
|
||||
'next_url': '/mandaye/auto_login',
|
||||
'empty_referer': True,
|
||||
'autologin_from': 'www.vincennes.fr'
|
||||
}
|
||||
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
'path': r"/(?!.*/associate)",
|
||||
'on_response': [{
|
||||
'filter': filters.resp_login_page,
|
||||
'content-types': ['text/html'],
|
||||
'values': {
|
||||
'connection_url': '/mandaye/connection',
|
||||
'template': 'famille/login.html',
|
||||
'title': 'Connexion via votre compte citoyen'
|
||||
}
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/login$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.login,
|
||||
'values': {
|
||||
'associate_url': '%s/associate' % folder_target,
|
||||
},
|
||||
'condition': 'response.code==302',
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'%s/associate$' % folder_target,
|
||||
'method': 'GET',
|
||||
'target': '%s/index.do' % folder_target,
|
||||
'on_response': [{
|
||||
'filter': filters.resp_associate,
|
||||
'values': {
|
||||
'action': '%s/associate' % folder_target,
|
||||
'template': 'famille/associate.html',
|
||||
'title': 'Associer un compte au compte citoyen de Vincennes',
|
||||
'badlogin_msg': "Code famille et/ou mot de passe incorrects",
|
||||
'failed_msg': "Vos identifiants pour l'espace famille ne fonctionnent plus ! Merci de les ressaisir.",
|
||||
},
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'%s/associate$' % folder_target,
|
||||
'method': 'POST',
|
||||
'response': [
|
||||
{
|
||||
'filter': auth.associate_submit,
|
||||
'values': {
|
||||
'associate_url': '%s/associate' % folder_target,
|
||||
'connection_url': '/mandaye/connection',
|
||||
},
|
||||
'condition': "response.code==302"
|
||||
},
|
||||
]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/connection$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.connection,
|
||||
'values': {
|
||||
'next_url': '/mandaye/login',
|
||||
}
|
||||
}]
|
||||
},
|
||||
{
|
||||
'path': r'%s/deconnexion.do$' % folder_target,
|
||||
'method': 'POST',
|
||||
'on_response': [{'filter': auth.logout},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/auto_login$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.auto_login,
|
||||
'values': {
|
||||
'associate_url': '%s/associate' % folder_target,
|
||||
},
|
||||
'condition': 'response.code==302',
|
||||
},]
|
||||
},
|
||||
{
|
||||
'path': r'/mandaye/disassociate$',
|
||||
'method': 'GET',
|
||||
'response': [{
|
||||
'filter': auth.disassociate,
|
||||
'values': {
|
||||
'next_url': '%s/affichage_accueil_prive.do' % folder_target,
|
||||
},
|
||||
}]
|
||||
},
|
||||
]
|
||||
|
|
@ -0,0 +1,254 @@
|
|||
import Cookie
|
||||
import mandaye
|
||||
import re
|
||||
|
||||
from urlparse import parse_qs
|
||||
from BeautifulSoup import BeautifulSoup
|
||||
import lxml.html
|
||||
|
||||
from mandaye.log import logger
|
||||
from mandaye.response import _302, _401
|
||||
from mandaye.template import serve_template
|
||||
|
||||
from mandaye.backend.default import ManagerSPUser
|
||||
|
||||
def get_associate_form(env, values):
|
||||
""" Return association template content
|
||||
"""
|
||||
associate_type = None
|
||||
error_msg = None
|
||||
first = False
|
||||
if env['QUERY_STRING']:
|
||||
qs = parse_qs(env['QUERY_STRING'])
|
||||
if qs.has_key('type'):
|
||||
associate_type = qs['type'][0]
|
||||
if associate_type == 'badlogin':
|
||||
error_msg = values.get('badlogin_msg')
|
||||
elif associate_type == 'failed':
|
||||
error_msg = values.get('failed_msg')
|
||||
elif associate_type == 'first':
|
||||
first = True
|
||||
form = serve_template(values.get('template'),
|
||||
first_connection=first, error_msg=error_msg,
|
||||
action_url=values.get('action') + "?%s" % env['QUERY_STRING'],**values)
|
||||
return form.encode('utf-8')
|
||||
|
||||
def get_current_account(env, values):
|
||||
""" Return the current Mandaye user """
|
||||
site_name = values.get('site_name')
|
||||
if env['beaker.session'].get(site_name):
|
||||
return ManagerSPUser.get_by_id(env['beaker.session'].get(site_name))
|
||||
else:
|
||||
return None
|
||||
|
||||
|
||||
def get_multi_template(env, values, current_account):
|
||||
""" return the content of the multi account template
|
||||
"""
|
||||
unique_id = env['beaker.session'].get('unique_id')
|
||||
if login:
|
||||
accounts = {}
|
||||
sp_users = ManagerSPUser.get_sp_users(unique_id,
|
||||
values.get('site_name'))
|
||||
for sp_user in sp_users:
|
||||
accounts[sp_user.id] = sp_user.login
|
||||
if current_account:
|
||||
current_login = current_account.login
|
||||
else:
|
||||
current_login = None
|
||||
template = serve_template(values.get('template'),
|
||||
accounts=accounts, current_login=current_login, **values)
|
||||
return template
|
||||
return None
|
||||
|
||||
|
||||
class Biblio:
|
||||
|
||||
def resp_html_login_page(self, env, values, request, response):
|
||||
""" msg: response message body
|
||||
env: Mandaye environment
|
||||
"""
|
||||
if '<div>Connexion utilisateur</div>' in response.msg:
|
||||
login = serve_template(values.get('template'), **values)
|
||||
sub = re.subn(r'<!-- /block.tpl.php -->\s*(<span class="clear"></span>)',
|
||||
r'\1 %s' % login.encode('utf-8'),
|
||||
response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] != 1:
|
||||
logger.warning('Filter Biblio.resp_html_login_page failed !')
|
||||
return response
|
||||
|
||||
def resp_html(self, env, values, request, response):
|
||||
""" Global html filter the Vincenne library
|
||||
This fix the fucking absolute url of the biblio site
|
||||
"""
|
||||
if response.msg:
|
||||
response.msg = response.msg.replace(env["target"].geturl(),
|
||||
'%s://%s' % (env["mandaye.scheme"], env["HTTP_HOST"]))
|
||||
if env["mandaye.scheme"] == 'https':
|
||||
response.msg = response.msg.replace('http://' + env["HTTP_HOST"],
|
||||
'%s://%s' % (env["mandaye.scheme"], env["HTTP_HOST"]))
|
||||
return response
|
||||
|
||||
def resp_associate_login(self, env, values, request, response):
|
||||
""" Use default login page to associate an account on the SSO
|
||||
"""
|
||||
if response.msg and '<div class="inner">' in response.msg:
|
||||
form = get_associate_form(env, values)
|
||||
r = re.compile(r'<div class="inner">.*</div><!-- / inner -->',
|
||||
re.MULTILINE|re.DOTALL)
|
||||
sub = re.subn(r, form, response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] != 1:
|
||||
logger.warning('Filter Biblio.resp_associate failed !')
|
||||
return response
|
||||
|
||||
def resp_multicompte_html(self, env, values, request, response):
|
||||
""" Modify response html to support multi accounts
|
||||
"""
|
||||
if response.msg and '<h2><div>Mon compte</div></h2>' in response.msg:
|
||||
if env['beaker.session'].get('unique_id'):
|
||||
current_account = get_current_account(env, values)
|
||||
template = get_multi_template(env, values, current_account)
|
||||
if current_account:
|
||||
sub = re.subn(r'(<div class="content"><div id="opacaccount" class="summary"><div class="name">)<b>(.*)</b>',
|
||||
r'\1<b>\2 (%s)</b>' % current_account.login.encode('utf-8'),
|
||||
response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] != 1:
|
||||
logger.warning('Filter Biblio.resp_multicompte_html: add card number in account information failed')
|
||||
desassociate = serve_template('biblio/disassociate.html',
|
||||
account=current_account, **values)
|
||||
sub = re.subn(r'<div class="link">', '<div class="link" style="margin-bottom: 10px">%s'\
|
||||
% desassociate.encode('utf-8'),
|
||||
response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] != 1:
|
||||
logger.warning('Filter Biblio.resp_multicompte_html: add disassociate link failed !')
|
||||
else:
|
||||
template = serve_template(values.get('nosso_template'), **values)
|
||||
regexp = re.compile(r'(<div id="opacaccount" class="summary">.*connecter</a></div></div>)',
|
||||
re.MULTILINE|re.DOTALL)
|
||||
sub = re.subn(regexp, r"\1 %s" % template.encode('utf-8'), response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] != 1:
|
||||
logger.warning('Filter Biblio.resp_multicompte_html: add multiaccount informations failed !')
|
||||
return response
|
||||
|
||||
|
||||
class EspaceFamille:
|
||||
|
||||
def resp_login_page(self, env, values, request, response):
|
||||
""" Modify the login_page form
|
||||
"""
|
||||
if response.msg and \
|
||||
'<!-- Bloc central > Bloc droite > Acc' in response.msg:
|
||||
login = serve_template(values.get('template'), **values)
|
||||
regexp = re.compile(r'(<!-- Bloc central > Bloc droite > Demandes -->)')
|
||||
sub = re.subn(regexp,
|
||||
r"\1%s" % login.encode('utf-8'), response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] != 1:
|
||||
logger.warning('Filter EspaceFamille.resp_login_page failed !')
|
||||
return response
|
||||
|
||||
def resp_associate(self, env, values, request, response):
|
||||
""" Modify associate page response """
|
||||
if response.msg:
|
||||
# TODO: remove BeautifulSoup
|
||||
soup = BeautifulSoup(response.msg)
|
||||
div = soup.find('div', {'class': 'bloc-model-1'})
|
||||
if div:
|
||||
form = get_associate_form(env, values)
|
||||
div.replaceWith(BeautifulSoup(form))
|
||||
response.msg = str(soup)
|
||||
else:
|
||||
logger.warning('Filter EspaceFamille.resp_associate failed !')
|
||||
return response
|
||||
|
||||
def resp_disassociate(self, env, values, resquest, response):
|
||||
""" Add a disassociation link
|
||||
"""
|
||||
if response.msg and\
|
||||
'<!-- Navigation -->' in response.msg:
|
||||
login = env['beaker.session'].get('unique_id')
|
||||
current_account = get_current_account(env, values)
|
||||
if login and current_account:
|
||||
disassociate = serve_template('famille/disassociate.html',
|
||||
account=current_account, **values)
|
||||
sub = re.subn(r'(connexion" /></p>)',
|
||||
r"\1%s" % disassociate.encode('iso8859-15'), response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] > 1:
|
||||
logger.warning('Filter EspaceFamille.disassociate failed !')
|
||||
return response
|
||||
|
||||
|
||||
class Duonet:
|
||||
|
||||
def resp_login_page(self, env, values, request, response):
|
||||
""" Modify login page to add the 'compte citoyen' connection
|
||||
"""
|
||||
if response.msg and '<form name="form1"' in response.msg:
|
||||
login = serve_template(values.get('template'), **values)
|
||||
regexp = re.compile(
|
||||
r'</table>.*<center>.*<span id="lblError".*</center>',
|
||||
re.MULTILINE|re.DOTALL)
|
||||
sub = re.subn(regexp,
|
||||
"</table>%s" % login.encode('utf-8'), response.msg)
|
||||
response.msg = sub[0]
|
||||
if sub[1] > 1:
|
||||
logger.warning('Filter Duonet.resp_login_page failed !')
|
||||
return response
|
||||
|
||||
def resp_associate(self, env, values, request, response):
|
||||
""" Add the associate form in the page
|
||||
"""
|
||||
if response.msg:
|
||||
# TODO: remove BeautifulSoup
|
||||
soup = BeautifulSoup(response.msg)
|
||||
form = soup.find('form', {'name': 'form1'})
|
||||
if form:
|
||||
new_form = get_associate_form(env, values)
|
||||
form.replaceWith(BeautifulSoup(new_form))
|
||||
response.msg = str(soup)
|
||||
return response
|
||||
|
||||
def resp_global_html(self, env, values, request, response):
|
||||
""" Modify response html to support disassociation and link to federate an account
|
||||
"""
|
||||
if response.msg \
|
||||
and 'font-weight:bold;">Conservatoire de Vincennes' in response.msg:
|
||||
login = env['beaker.session'].get('unique_id')
|
||||
site_name = values.get('site_name')
|
||||
current_account = get_current_account(env, values)
|
||||
if login and current_account:
|
||||
disassociate = serve_template('duonet/disassociate.html',
|
||||
account=current_account, **values)
|
||||
document = lxml.html.fromstring(response.msg.decode('utf8'))
|
||||
a = document.get_element_by_id('ctl00_lnkDisconnect')
|
||||
a.rewrite_links(lambda link: '/mandaye/logout')
|
||||
new_element = lxml.html.fromstring(disassociate)
|
||||
a.addprevious(new_element)
|
||||
response.msg = lxml.html.tostring(document, encoding='utf8')
|
||||
elif 'ctl00_chpMain_newsfeed_pnlBorder' in response.msg:
|
||||
template = serve_template(values.get('nosso_template'), **values)
|
||||
document = lxml.html.fromstring(response.msg.decode('utf8'))
|
||||
div = document.get_element_by_id('ctl00_chpMain_newsfeed_pnlBorder')
|
||||
new_element = lxml.html.fromstring(template)
|
||||
div.addnext(new_element)
|
||||
response.msg = lxml.html.tostring(document, encoding='utf8')
|
||||
return response
|
||||
|
||||
def logout(self, env, values, request, response):
|
||||
for cookie in request.cookies.itervalues():
|
||||
cookie['expires'] = 'Tue, 02-Dec-2003 08:19:12 GMT'
|
||||
cookie['Path'] = '/'
|
||||
logger.debug('Logout from Mandaye')
|
||||
env['beaker.session'].delete()
|
||||
return _302(values.get('index_url'), request.cookies)
|
||||
|
||||
|
||||
|
||||
|
||||
|
|
@ -0,0 +1,2 @@
|
|||
2013-10-27 21:51:52 INFO CAM rp start
|
||||
2013-10-27 21:52:48 INFO CAM rp start
|
|
@ -0,0 +1,47 @@
|
|||
|
||||
<div class="inner">
|
||||
<h1 class="title">Associer un compte</h1>
|
||||
|
||||
% if error_msg:
|
||||
<div class="messages error">
|
||||
${error_msg}
|
||||
</div>
|
||||
% endif
|
||||
% if first_connection:
|
||||
<p>
|
||||
C'est votre première connexion via le compte citoyen.
|
||||
Merci de saisir vos identifiants bilbliothèque pour que nous puissions les associer.
|
||||
La prochaine fois que vous vous connecterez sur l’espace médiathèque via
|
||||
votre compte citoyen, vous accéderez directement sur votre compte.
|
||||
Pour plus d'information, cliquer <a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide">ici</a>
|
||||
</p>
|
||||
% endif
|
||||
|
||||
<div class="node" id="node-470">
|
||||
<div class="content">
|
||||
<strong><u>N° de carte</u></strong> = les <u>6 derniers numéros </u>de la carte <br>
|
||||
<strong><u>Mot de passe</u></strong> = lors de la <u>première connexion votre nom de famille</u>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="block-connexion-utilisateur clear-block block block-dk_opac15" id="block-dk_opac15-login"><div id="blockContent">
|
||||
|
||||
<h2><div>Associer une carte à votre compte citoyen Vincennes</div></h2>
|
||||
|
||||
<div class="content"><center>
|
||||
<form id="dk-opac15-login-form" method="post" accept-charset="UTF-8" action="${action_url}">
|
||||
<div><div class="form-item">
|
||||
<label for="edit-user">Numéro de carte : <span title="Ce champ est obligatoire." class="form-required">*</span></label>
|
||||
<input type="text" class="form-text required" value="" size="19" id="edit-user" name="user" maxlength="128">
|
||||
</div>
|
||||
<div class="form-item">
|
||||
<label for="edit-password">Mot de passe : <span title="Ce champ est obligatoire." class="form-required">*</span></label>
|
||||
<input type="password" class="form-text required" size="19" id="edit-password" name="password">
|
||||
</div>
|
||||
<input type="submit" class="form-submit" value="Associer" id="edit-submit" name="op">
|
||||
<input type="hidden" value="dk_opac15_login_form" id="edit-dk-opac15-login-form" name="form_id">
|
||||
|
||||
</div></form>
|
||||
</center></div>
|
||||
</div></div>
|
||||
</div>
|
|
@ -0,0 +1,15 @@
|
|||
<script type="text/javascript">
|
||||
function disassociate_logout(account, id)
|
||||
{
|
||||
var r=confirm("Etes-vous sûr de vouloir désassocier le compte " + account + " ?");
|
||||
if (r==true)
|
||||
{
|
||||
window.location = "/mandaye/disassociate?id=" + id + "&logout=1";
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
<a href="javascript:disassociate_logout('${account.login}', ${account.id})"
|
||||
title="Cliquer ici pour supprimer l'association entre ce compte médiathèque et votre compte citoyen. Le compte médiathèque restera accessible par son propriétaire avec ses propres identifiants.">
|
||||
Désassocier</a>
|
|
@ -0,0 +1,19 @@
|
|||
<div id="block-dk_opac15-login" class="block-connexion-utilisateur clear-block block block-dk_opac15">
|
||||
<div id="blockContent" style='margin-top:12px'>
|
||||
|
||||
<h2><div>${title}</div></h2>
|
||||
|
||||
<div class="content">
|
||||
<center>
|
||||
<p>
|
||||
En cliquant sur le lien ci-dessous, vous vous connecterez en utilisant
|
||||
votre compte citoyen créé sur le site vincennes.fr. Pour plus d'information,
|
||||
<a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide" target="_blank">cliquer ici</a>.
|
||||
</p>
|
||||
<form action="${connection_url}" method="GET">
|
||||
<input type="submit" value="Se connecter" />
|
||||
</form>
|
||||
</center>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
|
@ -0,0 +1,32 @@
|
|||
<script type="text/javascript">
|
||||
function show_confirm(account, id)
|
||||
{
|
||||
var r=confirm("Etes-vous sûr de vouloir désassocier le compte " + account + " ?");
|
||||
if (r==true)
|
||||
{
|
||||
window.location = "/mandaye/disassociate?id=" + id;
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<div style='margin-top:10px;'>
|
||||
<h2 style='margin-bottom:5px;'>Autre(s) carte(s) (<a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide">+ d'information</a>)</h2>
|
||||
<ul>
|
||||
% for id, login in accounts.iteritems():
|
||||
% if login != current_login:
|
||||
<li style='margin-bottom:8px;'>
|
||||
<b>${login}</b><br />
|
||||
<a href="/mandaye/change_user?id=${id}">Se connecter</a> |
|
||||
<a href="javascript:show_confirm(${login}, ${id})"
|
||||
title="Cliquer ici pour supprimer l’association à ce compte. Le compte restera accessible par son propriétaire avec ses propres identifiants.">
|
||||
Désassocier</a>
|
||||
</li>
|
||||
%endif
|
||||
% endfor
|
||||
</ul>
|
||||
<p style='margin-top:10px; font-weight:bold;'>
|
||||
<a href="${associate_url}" title="Cliquer ici pour associer un nouveau compte. Vous
|
||||
pourrez ainsi être directement connecté et consulter un
|
||||
autre compte en plus du vôtre.">Ajouter une carte</a>
|
||||
</p>
|
||||
</div>
|
|
@ -0,0 +1,3 @@
|
|||
<p style='margin-top:10px; font-weight:bold;'>
|
||||
<a href="${associate_url}" title="Après association, vous pourrez vous connecter à ce compte en passant par votre compte citoyen créé sur vincennes.fr">Associer à mon compte citoyen</a> <a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide" target="_blank" style="color: black; font-weight: normal; font-size: 80%; text-decoration: none;" title="Cliquez ici pour obtenir des informations sur le compte citoyen vincennes.fr">(+ d'information)</a>
|
||||
</p>
|
|
@ -0,0 +1,106 @@
|
|||
<form name="form1" method="post" action="${action_url}" id="form1">
|
||||
|
||||
<center>
|
||||
|
||||
<div id="divMargin" style="height:100px"></div>
|
||||
<div id="pnlLogin" style="text-align:center;">
|
||||
|
||||
|
||||
<input type="hidden" name="hd" id="hd" value="800;1000" />
|
||||
<table width="100%" align="center">
|
||||
<tr >
|
||||
<td colspan="2" align="center">
|
||||
<img id="imgMain" src="http://www.parapharmacie-defrance.fr/lien/logo_mairie_vincennes.gif" style="height:120px;border-width:0px;" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
|
||||
<td colspan="2" style="padding-top:10px;padding-right:15px;">
|
||||
<div style="border:solid 1px black" >
|
||||
<span id="lblSchoolName" style="font-size:XX-Large;">Associer un compte au compte citoyen de Vincennes</span>
|
||||
</div>
|
||||
% if first_connection:
|
||||
<p>
|
||||
C'est votre première connexion via le compte citoyen.
|
||||
Merci de saisir vos identifiants bilbliothèque pour que nous puissions les associer.
|
||||
La prochaine fois que vous vous connecterez sur l’espace médiathèque via
|
||||
votre compte citoyen, vous accéderez directement sur votre compte.
|
||||
Pour plus d'information, <a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide">cliquer ici</a>
|
||||
</p>
|
||||
% endif
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
|
||||
<td colspan="2" align="center" lang="fr">
|
||||
<table>
|
||||
<tr valign="top">
|
||||
<td style="display:none">
|
||||
<a id="hlkExt" title="Nouveaux élève(s)/Consultation/Espace publique de l'établissement" href="External/Default.aspx" style="font-weight:bold;">Pas encore inscrit(e)?</a>
|
||||
</td>
|
||||
<td>
|
||||
<div id="pnlLog" style="background-color:LightGrey;">
|
||||
<table align="center" id="tbConnect" style="padding:10px 10px 10px 10px">
|
||||
|
||||
<tr>
|
||||
<td align="right">
|
||||
<span id="lblPassword">Nom de famille</span>
|
||||
</td>
|
||||
<td align="left">
|
||||
<input name="txtNomFoyer" type="text" id="txtNomFoyer" autocomplete="off" style="font-weight:bold;" />
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td align="right">
|
||||
<span id="lblDateDeNaissance">Date de Naissance</span>
|
||||
</td>
|
||||
|
||||
<td align="left">
|
||||
<input name="txtDateNaissance" type="text" id="txtDateNaissance" autocomplete="off" style="font-weight:bold;" />
|
||||
<span id="lblPassword1" style="font-size:XX-Small;font-style:italic;">(Ex: 16/06/2008)</span>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
|
||||
<td align="right">
|
||||
<span id="lblLogin">Code DuoNET</span>
|
||||
</td>
|
||||
<td align="left" style="padding-left:3px">
|
||||
<input name="txtCode" type="password" maxlength="13" id="txtCode" autocomplete="off" style="font-weight:bold;width:121px;" />
|
||||
<span id="lblPassword2" style="font-size:XX-Small;font-style:italic;">(Ex: 1994000001001)</span>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
|
||||
<tr>
|
||||
<td align="center" colspan="2">
|
||||
<input type="submit" name="btnConnect" value="Associer" id="btnConnect" style="font-weight:bold;" />
|
||||
<div id="upChooseRole">
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
</table>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
<center>
|
||||
|
||||
% if error_msg:
|
||||
<span id="lblError" style="color:Red;font-weight:bold;">${error_msg}</span>
|
||||
% endif
|
||||
</center>
|
||||
</div>
|
||||
</center>
|
||||
|
||||
<div id="pnlLoadModal" style="background-color:White;border:solid 1px black;padding:3px 3px 3px 3px;display:none">
|
||||
<img id="imgLoadModal" src="Images/loading1.gif" style="border-width:0px;" />
|
||||
</div>
|
||||
</form>
|
||||
|
|
@ -0,0 +1,13 @@
|
|||
<script type="text/javascript">
|
||||
function disassociate_logout(account, id)
|
||||
{
|
||||
var r=confirm("Etes-vous sûr de vouloir désassocier le compte " + account + " ?");
|
||||
if (r==true)
|
||||
{
|
||||
window.location = "/mandaye/disassociate?id=" + id + "&logout=1";
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
<a style="font-size:XX-Small;font-weight:bold;margin-right:10px;" href="javascript:disassociate_logout('${account.login}', ${account.id})">Désassocier</a>
|
|
@ -0,0 +1,33 @@
|
|||
<tr border=1>
|
||||
<td colspan="2" align="center" lang="fr">
|
||||
<div id="pnlLoadModal" style="background-color: white; border-top-style: solid; border-right-style: solid; border-bottom-style: solid; border-left-style: solid; border-top-width: 1px; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-top-color: black; border-right-color: black; border-bottom-color: black; border-left-color: black; padding-top: 3px; padding-right: 3px; padding-bottom: 3px; padding-left: 3px; display: none; position: fixed; z-index: 100001; ">
|
||||
<img id="imgLoadModal" src="Images/loading1.gif" style="border-width:0px;">
|
||||
</div>
|
||||
<table>
|
||||
<tbody><tr valign="top">
|
||||
<td>
|
||||
<div id="pnlLog" style="background-color:LightGrey;">
|
||||
<table align="center" id="tbConnect" style="padding:10px 60px 10px 60px; ">
|
||||
<tbody align="center">
|
||||
<tr>
|
||||
<td>
|
||||
<h3 style="margin:0 0 5px 0; padding:0;">Connexion via le compte citoyen</h3>
|
||||
En cliquant sur le lien ci-dessous, vous vous connecterez
|
||||
<br />en utilisant votre compte citoyen créé sur le site vincennes.fr.<br />Pour plus d'information,
|
||||
<a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide" target="_blank">cliquer ici</a>.
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<a href="${connection_url}"><button type='button' onclick="location.replace('${connection_url}')" style="font-weight:bold;">Connexion</button></a>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</td>
|
||||
</tr>
|
|
@ -0,0 +1,37 @@
|
|||
<script type="text/javascript">
|
||||
function show_confirm(account, id)
|
||||
{
|
||||
var r=confirm("etes-vous sûr de vouloir désassocier le compte " + account + " ?");
|
||||
if (r==true)
|
||||
{
|
||||
window.location = "/mandaye/disassociate?id=" + id;
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<tr>
|
||||
<td style="padding-top:10px;padding-right:30px">
|
||||
<br>
|
||||
<div style="width: 100%; background-color: transparent; vertical-align: top; padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; "><div style="margin-left: 10px; margin-right: 8px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; background-color: black; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 6px; margin-right: 4px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 4px; border-right-width: 4px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 4px; margin-right: 2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 2px; border-right-width: 2px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 3px; margin-right: 1px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 2px; margin-right: 0px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 1px; margin-right: -1px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 1px; margin-right: -1px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 0px; margin-right: -2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 0px; margin-right: -2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 0px; margin-right: -2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div id="" style="background-color: white; width: 100%; border-top-style: none; border-bottom-style: none; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; ">
|
||||
|
||||
<div style="padding:8px 8px 8px 8px">
|
||||
<h3>Autres comptes associés</h3>
|
||||
<ul>
|
||||
% for id, account in accounts.iteritems():
|
||||
% if account != current_login:
|
||||
<li style='margin-bottom:8px;'>
|
||||
<b>${account}</b><br />
|
||||
<a href="/mandaye/change_user?id=${id}">Se connecter</a> |
|
||||
<a href="javascript:show_confirm('${account}', ${id})" title="bla bla bla">Désassocier</a>
|
||||
</li>
|
||||
%endif
|
||||
% endfor
|
||||
</ul>
|
||||
<p style='margin-top:10px; font-weight:bold;'>
|
||||
<a href="${associate_url}">Associer un nouveau compte</a>
|
||||
</p>
|
||||
</div>
|
||||
|
||||
</div><div style="background-color: rgb(255, 255, 255); margin-left: 0px; margin-right: -2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 0px; margin-right: -2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 0px; margin-right: -2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 1px; margin-right: -1px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 1px; margin-right: -1px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 2px; margin-right: 0px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 3px; margin-right: 1px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 4px; margin-right: 2px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 2px; border-right-width: 2px; "></div><div style="background-color: rgb(255, 255, 255); margin-left: 6px; margin-right: 4px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 4px; border-right-width: 4px; "></div><div style="margin-left: 10px; margin-right: 8px; height: 1px; font-size: 1px; overflow-x: hidden; overflow-y: hidden; border-left-style: solid; border-right-style: solid; border-left-color: black; border-right-color: black; border-left-width: 1px; border-right-width: 1px; background-color: black; "></div></div>
|
||||
</td>
|
||||
</tr>
|
|
@ -0,0 +1,3 @@
|
|||
<p style='margin-top:10px; font-weight:bold;'>
|
||||
<a href="${associate_url}" title="Après association, vous pourrez vous connecter à ce compte en passant par votre compte citoyen créé sur vincennes.fr">Associer à mon compte citoyen</a> <a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide" target="_blank" style="color: black; font-weight: normal; font-size: 80%; text-decoration: none;" title="Cliquez ici pour obtenir des informations sur le compte citoyen vincennes.fr">(+ d'information)</a>
|
||||
</p>
|
|
@ -0,0 +1,29 @@
|
|||
<div class="bloc-model-1">
|
||||
<h2>${title}</h2>
|
||||
<div class="bloc-gris">
|
||||
<form action="${action_url}" method="post">
|
||||
<div class="form">
|
||||
% if error_msg:
|
||||
<div id="list-errors">
|
||||
<p class="errors"><b>${error_msg}</b><br></p>
|
||||
</div>
|
||||
% endif
|
||||
% if first_connection:
|
||||
<div>
|
||||
C'est votre première connexion via le compte citoyen.
|
||||
Merci de saisir vos identifiants à l'espace famille pour que nous puissions les associer.
|
||||
La prochaine fois que vous vous connecterez sur l’espace famille via
|
||||
votre compte citoyen, vous accéderez directement sur votre compte.
|
||||
Pour plus d'information, <a style="background: none; margin: 0; padding: 0;" href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide">cliquer ici</a>
|
||||
<br><br></div>
|
||||
% endif
|
||||
<div class="firstline">
|
||||
<label for="cdfmll" class="first"><b>⇒</b> Code famille</label> :
|
||||
<input type="text" id="cdfmll" class="txt" name="codeFamille" title="Indiquez votre code famille"><br>
|
||||
<label for="mtdpss"><b>⇒</b> Mot de passe</label> :
|
||||
<input type="password" id="mtdpss" class="txt" name="motDePasse" title="Indiquez votre mot de passe"></div>
|
||||
<input type="submit" class="submit" value="Associer"><br>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
|
@ -0,0 +1,18 @@
|
|||
<script type="text/javascript">
|
||||
function disassociate_logout(account, id)
|
||||
{
|
||||
var r=confirm("Etes-vous sûr de vouloir désassocier le compte " + account + " ?");
|
||||
if (r==true)
|
||||
{
|
||||
window.location = "/mandaye/disassociate?id=" + id + "&logout=1";
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
<p>
|
||||
<input type="button" title="Cliquer ici pour supprimer l'association entre cet espace famille et votre compte citoyen. L'espace famille restera accessible par son propriétaire avec ses propres identifiants."
|
||||
style="float: right; margin: 15px 15px 15px 15px; padding: 0px 5px 0px 5px;
|
||||
font-size: 1em; font-weight: bold; color: #7B7A78; background-color: #F6F5F1;
|
||||
border: 1px solid #ACABA8;" onClick="javascript:disassociate_logout('${account.login}', ${account.id})" value="Désassocier">
|
||||
</p>
|
|
@ -0,0 +1,15 @@
|
|||
<div class="bloc-model-1">
|
||||
<h2>${title}</h2>
|
||||
<div class="bloc-gris" style='text-align:center'>
|
||||
<div style='margin-bottom:8px'>
|
||||
En cliquant sur le lien ci-dessous, vous vous connecterez en utilisant votre
|
||||
compte citoyen créé sur le site vincennes.fr.
|
||||
<br />Pour plus d'information, <a href="http://www.vincennes.fr/Vos-demarches/Compte-citoyen/Aide" target="_blank">cliquer ici</a>.
|
||||
</div>
|
||||
<form action="${connection_url}" method="GET">
|
||||
<div class='form'>
|
||||
<input type="submit" class="submit" value="Connectez-vous" />
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
|
@ -0,0 +1,13 @@
|
|||
|
||||
import os
|
||||
|
||||
from mandaye.server import MandayeApp
|
||||
|
||||
from mandaye_vincennes import config
|
||||
from beaker.middleware import SessionMiddleware
|
||||
|
||||
os.environ['MANDAYE_CONFIG_MODULE'] = 'mandaye_vincennes.config'
|
||||
|
||||
application = SessionMiddleware(MandayeApp(), config.session_opts)
|
||||
|
||||
|
|
@ -0,0 +1,78 @@
|
|||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
""" Script to administrate mandaye server
|
||||
"""
|
||||
|
||||
import os
|
||||
os.environ['MANDAYE_CONFIG_MODULE'] = 'cam.config'
|
||||
|
||||
import base64
|
||||
|
||||
from optparse import OptionParser
|
||||
|
||||
from mandaye import config
|
||||
from mandaye.log import logger
|
||||
|
||||
def get_cmd_options():
|
||||
usage = "usage: %prog --createdb|--upgradedb|--cryptpwd"
|
||||
parser = OptionParser(usage=usage)
|
||||
parser.add_option("--createdb",
|
||||
dest="createdb",
|
||||
default=False,
|
||||
action="store_true",
|
||||
help="Create Mandaye database"
|
||||
)
|
||||
parser.add_option("--upgradedb",
|
||||
dest="upgradedb",
|
||||
default=False,
|
||||
action="store_true",
|
||||
help="Upgrade Mandaye database"
|
||||
)
|
||||
parser.add_option("--cryptpwd",
|
||||
dest="cryptpwd",
|
||||
default=False,
|
||||
action="store_true",
|
||||
help="Crypt external password in Mandaye's database"
|
||||
)
|
||||
(options, args) = parser.parse_args()
|
||||
return options
|
||||
|
||||
def encrypt_pwd(pwd):
|
||||
from Crypto.Cipher import AES
|
||||
logger.debug("Encrypt password")
|
||||
enc_pwd = pwd
|
||||
if config.encrypt_secret:
|
||||
try:
|
||||
cipher = AES.new(config.encrypt_secret, AES.MODE_CFB)
|
||||
enc_pwd = cipher.encrypt(pwd)
|
||||
enc_pwd = base64.b64encode(enc_pwd)
|
||||
except Exception, e:
|
||||
if config.debug:
|
||||
traceback.print_exc()
|
||||
logger.warning('Password encrypting failed %s' % e)
|
||||
else:
|
||||
logger.warning("You must set a secret to use pwd encryption")
|
||||
return enc_pwd
|
||||
|
||||
def main():
|
||||
options = get_cmd_options()
|
||||
if options.createdb or options.upgradedb:
|
||||
logger.info("Creating or upgrading database...")
|
||||
from alembic.config import Config
|
||||
from alembic import command
|
||||
from mandaye import global_config
|
||||
alembic_cfg = Config(global_config.alembic_cfg)
|
||||
alembic_cfg.set_main_option("script_location", global_config.alembic_script_path)
|
||||
command.upgrade(alembic_cfg, "head")
|
||||
logger.info("Database upgraded")
|
||||
if options.cryptpwd:
|
||||
pass
|
||||
#from mandaye.backends.default import ManagerSPUser
|
||||
#for user in ManagerSPUser.all():
|
||||
# user.password = encrypt_pwd(user.password)
|
||||
#ManagerSPUser.save()
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
|
@ -0,0 +1,31 @@
|
|||
#!/usr/bin/env python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
""" Script to launch mandaye with gunicorn server
|
||||
"""
|
||||
|
||||
import os
|
||||
os.environ['MANDAYE_CONFIG_MODULE'] = 'mandaye_vincennes.config'
|
||||
|
||||
import sys
|
||||
|
||||
from mandaye.log import logger
|
||||
from gunicorn.app.wsgiapp import WSGIApplication
|
||||
|
||||
class WSGIApplication(WSGIApplication):
|
||||
|
||||
def init(self, parser, opts, args):
|
||||
self.cfg.set("default_proc_name", "mandaye_vincennes.wsgi:application")
|
||||
self.app_uri = "mandaye_vincennes.wsgi:application"
|
||||
|
||||
sys.path.insert(0, os.getcwd())
|
||||
|
||||
def main():
|
||||
""" The ``gunicorn`` command line runner for launcing Gunicorn with
|
||||
generic WSGI applications.
|
||||
"""
|
||||
logger.info('CAM rp start')
|
||||
WSGIApplication("%prog [OPTIONS]").run()
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
|
@ -0,0 +1,46 @@
|
|||
#! /usr/bin/env python
|
||||
|
||||
'''
|
||||
Setup script for Vincennes RP
|
||||
'''
|
||||
|
||||
import os
|
||||
import subprocess
|
||||
|
||||
from setuptools import setup, find_packages
|
||||
from sys import version
|
||||
|
||||
install_requires=[
|
||||
'gunicorn>=0.13',
|
||||
'mandaye>=0.4',
|
||||
'pycrypto>=2.0',
|
||||
]
|
||||
|
||||
def get_version():
|
||||
if os.path.exists('VERSION'):
|
||||
version_file = open('VERSION', 'r')
|
||||
version = version_file.read()
|
||||
version_file.close()
|
||||
return version
|
||||
if os.path.exists('.git'):
|
||||
p = subprocess.Popen(['git','describe','--long'], stdout=subprocess.PIPE)
|
||||
result = p.communicate()[0]
|
||||
return result.split()[0].replace('-','.')
|
||||
import mandaye_vincennes
|
||||
return mandaye_vincennes.VERSION
|
||||
|
||||
setup(name="mandaye-vincennes",
|
||||
version=get_version(),
|
||||
license="AGPLv3 or later",
|
||||
description="Vincennes rp is a Mandaye project, modular reverse proxy to authenticate",
|
||||
url="http://dev.entrouvert.org/projects/reverse-proxy/",
|
||||
author="Entr'ouvert",
|
||||
author_email="info@entrouvert.org",
|
||||
maintainer="Jerome Schneider",
|
||||
maintainer_email="jschneider@entrouvert.com",
|
||||
scripts=['mandaye_vincennes_manager', 'mandaye_vincennes_server'],
|
||||
packages=find_packages(),
|
||||
include_package_data=True,
|
||||
install_requires=install_requires
|
||||
)
|
||||
|
|
@ -0,0 +1,10 @@
|
|||
go http://biblio-sso.vincennes.fr/mandaye/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
show_cookies
|
||||
find 'Associer une carte'
|
||||
fv 1 username 754443
|
||||
fv 1 password lecteur
|
||||
submit
|
||||
find 'Mon compte'
|
|
@ -0,0 +1,10 @@
|
|||
go http://biblio-sso.vincennes.fr/mandaye/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
find 'Test \(754443\)'
|
||||
go http://biblio-sso.vincennes.fr/mandaye/disassociate?username=754443
|
||||
url https://biblio-sso.vincennes.fr/sezhame/
|
||||
go http://biblio-sso.vincennes.fr/sezhame/logout
|
||||
go http://biblio-sso.vincennes.fr/mandaye/connection
|
||||
find 'Associer une carte'
|
|
@ -0,0 +1,5 @@
|
|||
go http://biblio-sso.vincennes.fr/mandaye/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
find 'Mon compte'
|
|
@ -0,0 +1,16 @@
|
|||
config use_tidy 0
|
||||
config use_BeautifulSoup 0
|
||||
config allow_parse_errors 0
|
||||
go https://conservatoire.vincennes.fr/
|
||||
find 'vincennes/connection'
|
||||
go https://conservatoire.vincennes.fr/vincennes/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
find 'Associer un compte'
|
||||
fv 1 username LAGAFFE
|
||||
fv 1 birthdate 23/04/1991
|
||||
fv 1 password 2012000086001
|
||||
submit
|
||||
find 'LAGAFFE Gaston'
|
||||
|
|
@ -0,0 +1,19 @@
|
|||
config use_tidy 0
|
||||
config use_BeautifulSoup 0
|
||||
config allow_parse_errors 0
|
||||
go https://conservatoire.vincennes.fr/
|
||||
find 'vincennes/connection'
|
||||
go https://conservatoire.vincennes.fr/vincennes/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
find 'LAGAFFE Gaston'
|
||||
go https://conservatoire.vincennes.fr/mandaye/disassociate?username=LAGAFFE
|
||||
clear_cookies
|
||||
go https://conservatoire.vincennes.fr/
|
||||
find 'vincennes/connection'
|
||||
go https://conservatoire.vincennes.fr/vincennes/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
find 'Associer un compte'
|
|
@ -0,0 +1,10 @@
|
|||
config use_tidy 0
|
||||
config use_BeautifulSoup 0
|
||||
config allow_parse_errors 0
|
||||
go https://conservatoire.vincennes.fr/
|
||||
find 'vincennes/connection'
|
||||
go https://conservatoire.vincennes.fr/vincennes/connection
|
||||
fv 2 ident bdauvergne@entrouvert.com
|
||||
fv 2 pwd eu1Ulida
|
||||
submit
|
||||
find 'LAGAFFE Gaston'
|
Reference in New Issue