NAME
Lemonldap::NG::Common::Apache::Session::SOAP - Perl extension written to access to Lemonldap::NG Web-SSO sessions via SOAP.
SYNOPSIS
With Lemonldap::NG::Handler
package
My::Package;
our
@ISA
=
qw(Lemonldap::NG::Handler::Simple)
;
__PACKAGE__->init ({
globalStorage
=>
'Lemonldap::NG::Common::Apache::Session::SOAP'
,
globalStorageOptions
=> {
proxyOptions
=> {
timeout
=> 5,
},
# If soapserver is protected by HTTP Basic:
User
=>
'http-user'
,
Password
=>
'pass'
,
# To have a local session cache
localStorage
=>
"Cache::FileCache"
,
localStorageOptions
=> {
'namespace'
=>
'lemonldap-ng'
,
'default_expires_in'
=> 600,
},
},
configStorage
=> {
...
# See Lemonldap::NG::Handler
With Lemonldap::NG::Portal
my
$portal
= new Lemonldap::NG::Portal::SharedConf (
globalStorage
=>
'Lemonldap::NG::Common::Apache::Session::SOAP'
,
globalStorageOptions
=> {
proxyOptions
=> {
timeout
=> 5,
},
# If soapserver is protected by HTTP Basic:
User
=>
'http-user'
,
Password
=>
'pass'
,
# To have a local session cache
localStorage
=>
"Cache::FileCache"
,
localStorageOptions
=> {
'namespace'
=>
'lemonldap-ng'
,
'default_expires_in'
=> 600,
},
},
configStorage
=> {
...
# See Lemonldap::NG::Portal
You can also set parameters corresponding to "Apache::Session module" in the manager.
DESCRIPTION
Lemonldap::NG::Common::Conf provides a simple interface to access to Lemonldap::NG Web-SSO configuration. It is used by Lemonldap::NG::Handler, Lemonldap::NG::Portal and Lemonldap::NG::Manager.
Lemonldap::NG::Common::Apache::Session::SOAP used with Lemonldap::NG::Portal provides the ability to access to Lemonldap::NG sessions via SOAP: the portal act as a proxy to access to the real Apache::Session module (see HTML documentation for more)
SECURITY
As Lemonldap::NG::Common::Conf::SOAP use SOAP::Lite, you have to see SOAP::Transport to know arguments that can be passed to proxyOptions
. Lemonldap::NG provides a system for HTTP basic authentication.
Examples :
HTTP Basic authentication
SOAP::transport can use basic authentication by rewriting
SOAP::Transport::HTTP::Client::get_basic_credentials>:
package
My::Package;
use
base Lemonldap::NG::Handler::SharedConf;
__PACKAGE__->init ( {
globalStorage
=>
'Lemonldap::NG::Common::Apache::Session::SOAP'
,
globalStorageOptions
=> {
User
=>
'http-user'
,
Password
=>
'pass'
,
},
} );
SSL Authentication
SOAP::transport provides a simple way to use SSL certificate: you've just to set environment variables.
package
My::Package;
use
base Lemonldap::NG::Handler::SharedConf;
# AUTHENTICATION
$ENV
{HTTPS_CERT_FILE} =
'client-cert.pem'
;
$ENV
{HTTPS_KEY_FILE} =
'client-key.pem'
;
__PACKAGE__->init ( {
globalStorage
=>
'Lemonldap::NG::Common::Apache::Session::SOAP'
,
globalStorageOptions
=> {
},
} );
SEE ALSO
Lemonldap::NG::Manager, Lemonldap::NG::Common::Conf::SOAP, Lemonldap::NG::Handler, Lemonldap::NG::Portal, http://lemonldap-ng.org/
AUTHORS
- LemonLDAP::NG team http://lemonldap-ng.org/team
BUG REPORT
Use OW2 system to report bug or ask for features: https://gitlab.ow2.org/lemonldap-ng/lemonldap-ng/issues
DOWNLOAD
Lemonldap::NG is available at https://lemonldap-ng.org/download
COPYRIGHT AND LICENSE
See COPYING file for details.
This library is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.