Lemonldap::NG::Common::Conf::SOAP.3pm

Langue: en

Autres versions - même langue

Version: 2009-06-29 (ubuntu - 24/10/10)

Section: 3 (Bibliothèques de fonctions)

NAME

Lemonldap::NG::Common::Conf::SOAP - Perl extension written to access to Lemonldap::NG Web-SSO configuration via SOAP.

SYNOPSIS

Client side

Area protection (Apache handler)
   package My::Package;
   
   use base Lemonldap::NG::Handler::SharedConf;
   
   __PACKAGE__->init ( {
       localStorage        => "Cache::FileCache",
       localStorageOptions => {
                 'namespace'          => 'MyNamespace',
                 'default_expires_in' => 600,
       },
       configStorage       => {
                 type     => 'SOAP',
                 proxy    => 'http://auth.example.com/index.pl/config',
                 # If soapserver is protected by HTTP Basic:
                 User     => 'http-user',
                 Password => 'pass',
       },
       https               => 0,
   } );
 
 

Authentication portal

   use Lemonldap::NG::Portal::SharedConf;
   
   my $portal = Lemonldap::NG::Portal::SharedConf->new ( {
           configStorage => {
                   type    => 'SOAP',
                   proxy    => 'http://auth.example.com/index.pl/config',
                   # If soapserver is protected by HTTP Basic:
                   User     => 'http-user',
                   Password => 'pass',
           }
   });
   # Next as usual... See Lemonldap::NG::Portal(3)
   if($portal->process()) {
     ...
 
 

Manager

   use Lemonldap::NG::Manager;
   
   my $m=new Lemonldap::NG::Manager(
        {
            configStorage=>{
                   type  => 'SOAP',
                   proxy    => 'http://auth.example.com/index.pl/config',
                   # If soapserver is protected by HTTP Basic:
                   User     => 'http-user',
                   Password => 'pass',
            },
             dhtmlXTreeImageLocation=> "/imgs/",
         }
   ) or die "Unable to start manager";
   
   $m->doall();
 
 

Server side

You just have to set ``Soap => 1'' in your portal. See HTML documentation for more.

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::Conf::SOAP provides the ``SOAP'' target used to access configuration via SOAP.

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
   package My::Package;
   
   use base Lemonldap::NG::Handler::SharedConf;
   
   __PACKAGE__->init ( {
       localStorage        => "Cache::FileCache",
       localStorageOptions => {
                 'namespace'          => 'MyNamespace',
                 'default_expires_in' => 600,
       },
       configStorage       => {
                 type  => 'SOAP',
                 proxy => 'http://auth.example.com/index.pl/config',
                 User     => 'http-user',
                 Password => 'pass',
       },
       https               => 1,
   } );
 
 
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 ( {
       localStorage        => "Cache::FileCache",
       localStorageOptions => {
                 'namespace'          => 'MyNamespace',
                 'default_expires_in' => 600,
       },
       configStorage       => {
                 type  => 'SOAP',
                 proxy => 'http://auth.example.com/index.pl/config',
       },
       https               => 1,
   } );
 
 

SEE ALSO

Lemonldap::NG::Common::Conf::SOAP, Lemonldap::NG::Handler, Lemonldap::NG::Portal, http://wiki.lemonldap.objectweb.org/xwiki/bin/view/NG/Presentation

AUTHOR

Xavier Guimard, <x.guimard@free.fr>

BUG REPORT

Use OW2 system to report bug or ask for features: <http://forge.objectweb.org/tracker/?group_id=274>

DOWNLOAD

Lemonldap::NG is available at <http://forge.objectweb.org/project/showfiles.php?group_id=274> Copyright (C) 2007 by Xavier Guimard

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.