CDA.pm 2.88 KB
Newer Older
Yadd's avatar
Yadd committed
1 2 3 4 5
##@file
# Cross-domain mechanism for handler

##@class
# Cross-domain mechanism for handler
6
package Lemonldap::NG::Handler::CDA;
7 8 9 10 11

use strict;

use Lemonldap::NG::Handler::SharedConf qw(:all);

12
our $VERSION = '0.2';
13

14
use base qw(Lemonldap::NG::Handler::SharedConf);
15

Yadd's avatar
Yadd committed
16
## @rmethod int run(Apache2::RequestRec apacheRequest)
Yadd's avatar
Yadd committed
17 18 19
# overload run subroutine to implement cross-domain mechanism.
# @param $apacheRequest
# @return Apache constant
20 21
sub run ($$) {
    my $class;
Yadd's avatar
Yadd committed
22 23
    $cda = 1;
    return $class->SUPER::run($apacheRequest);
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
}

1;
__END__

=head1 NAME

Lemonldap::NG::Handler::CDA - Module to use Lemonldap::NG::Handler
mechanisms with Cross-Domain-Authentication.

=head1 SYNOPSIS

New usage:

  package My::Package;
Yadd's avatar
Yadd committed
39 40
  use Lemonldap::NG::Handler;
  @ISA = qw(Lemonldap::NG::Handler);
41
  __PACKAGE__->init ( {
Yadd's avatar
Yadd committed
42
    cda                 => 1,
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
    localStorage        => "Cache::FileCache",
    localStorageOptions => {
        'namespace' => 'MyNamespace',
        'default_expires_in' => 600,
      },
    reloadTime          => 1200, # Default: 600
    configStorage       => {
       type                => "DBI"
       dbiChain            => "DBI:mysql:database=$database;host=$hostname;port=$port",
       dbiUser             => "lemonldap",
       dbiPassword         => "password",
    },
  } );

Call your package in /apache-dir/conf/httpd.conf :

  PerlRequire MyFile
  # TOTAL PROTECTION
  PerlHeaderParserHandler My::Package
  # OR SELECTED AREA
  <Location /protected-area>
    PerlHeaderParserHandler My::Package
  </Location>

The configuration is loaded only at Apache start. Create an URI to force
configuration reload, so you don't need to restart Apache at each change :

  # /apache-dir/conf/httpd.conf
  <Location /location/that/I/ve/choosed>
    Order deny,allow
    Deny from all
    Allow from my.manager.com
    PerlHeaderParserHandler My::Package->refresh
  </Location>

=head1 DESCRIPTION

This library inherit from L<Lemonldap::NG::Handler::SharedConf> and add the
capability to control users that are authenticated with a
82
L<Lemonldap::NG::Portal::CDA> CGI in another domain.
83 84 85 86 87 88 89 90

=head2 EXPORT

Same as L<Lemonldap::NG::Handler::SharedConf>.

=head1 SEE ALSO

L<Lemonldap::NG::Manager>, L<Lemonldap::NG::Handler>,
Yadd's avatar
Yadd committed
91 92
L<Lemonldap::NG::Handler::SharedConf>,
http://wiki.lemonldap.objectweb.org/xwiki/bin/view/NG/Presentation
93 94 95 96 97

=head1 AUTHOR

Xavier Guimard, E<lt>x.guimard@free.frE<gt>

Yadd's avatar
Yadd committed
98 99 100 101 102 103 104 105 106 107
=head1 BUG REPORT

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

=head1 DOWNLOAD

Lemonldap::NG is available at
L<http://forge.objectweb.org/project/showfiles.php?group_id=274>

108 109 110 111 112 113 114 115 116 117
=head1 COPYRIGHT AND LICENSE

Copyright (C) 2007 by Xavier Guimard E<lt>x.guimard@free.frE<gt>

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.4 or,
at your option, any later version of Perl 5 you may have available.

=cut