Reformating

This commit is contained in:
Xavier Guimard 2010-05-02 11:37:25 +00:00
parent 2f3d24ed72
commit cf0ece9aa2
2 changed files with 60 additions and 91 deletions

View File

@ -34,16 +34,13 @@ sub authInit {
sub extractFormInfo {
my $self = shift;
my $server = $self->{_lassoServer};
my $login;
my $logout;
my $idp;
my $idpConfKey;
my $method;
my $request;
my $response;
my $artifact;
my $relaystate;
my $signature_status;
# TODO: seems to be unused (redefined later)
my (
$login, $logout, $idp,
$idpConfKey, $request, $response,
$artifact, $relaystate, $signature_status
);
# 1. Get HTTP request informations to know
# if we are receving SAML request or response
@ -69,11 +66,11 @@ sub extractFormInfo {
"samlSPSSODescriptorArtifactResolutionServiceArtifact");
# 1.1 SSO assertion consumer
# TODO: if $saml_acs_art_url,... are fixed, add a /o
if ( $url =~
/^(\Q$saml_acs_art_url\E|\Q$saml_acs_post_url\E|\Q$saml_acs_get_url\E)$/i
)
{
$self->lmLog( "URL $url detected as an SSO assertion consumer URL",
'debug' );
@ -299,7 +296,7 @@ sub extractFormInfo {
}
# 1.2 SLO
if ( $url =~
elsif ( $url =~
/^(\Q$saml_slo_soap_url\E|\Q$saml_slo_soap_url_ret\E|\Q$saml_slo_get_url\E|\Q$saml_slo_get_url_ret\E)$/i
)
{
@ -544,7 +541,7 @@ sub extractFormInfo {
}
# HTTP-POST
if ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
# Use autosubmit form
my $slo_url = $logout->msg_url;
@ -566,7 +563,7 @@ sub extractFormInfo {
}
# HTTP-SOAP
if ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
my $slo_body = $logout->msg_body;
@ -596,7 +593,7 @@ sub extractFormInfo {
}
# 1.3 Artifact
if ( $url =~ /^(\Q$saml_ars_url\E)$/i ) {
elsif ( $url =~ /^(\Q$saml_ars_url\E)$/i ) {
$self->lmLog( "URL $url detected as an artifact resolution service URL",
'debug' );
@ -713,7 +710,7 @@ sub extractFormInfo {
}
# If IDP is found but not confirmed, let the user confirm it
if ( $confirm_flag != 1 ) {
elsif ( $confirm_flag != 1 ) {
$self->lmLog( "IDP $idp selected, need user confirmation", 'debug' );
# Choosen IDP
@ -858,7 +855,7 @@ sub extractFormInfo {
}
# HTTP-POST
if ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
# Use autosubmit form
my $sso_url = $login->msg_url;
@ -1070,7 +1067,7 @@ sub authLogout {
}
# HTTP-POST
if ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
# Use autosubmit form
my $slo_url = $logout->msg_url;
@ -1084,7 +1081,7 @@ sub authLogout {
}
# HTTP-SOAP
if ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
my $slo_url = $logout->msg_url;
my $slo_body = $logout->msg_body;

View File

@ -14,8 +14,9 @@ use LWP::UserAgent; # SOAP call
use HTTP::Request; # SOAP call
use POSIX; # Convert SAML2 date into timestamp
use Encode; # Encode attribute values
use Date::Format
our $VERSION = '0.01';
our $VERSION = '0.01';
our $_samlCache;
BEGIN {
@ -262,19 +263,13 @@ sub loadSPs {
# @param profile_type login or logout
# @return ( $request, $response, $method, $relaystate, $artifact )
sub checkMessage {
my $self = shift;
my $url = shift;
my $request_method = shift;
my $content_type = shift;
my $profile_type = shift || "login";
my $request;
my $response;
my $message;
my $method;
my $relaystate;
my $artifact;
my ( $self, $url, $request_method, $content_type, $profile_type ) =
splice @_;
$profile_type ||= "login";
my ( $request, $response, $message, $method, $relaystate, $artifact );
# Check if SAML service is loaded
# TODO : return undefined values ???
return ( $request, $response, $method, $relaystate, $artifact )
unless $self->{_lassoServer};
@ -362,7 +357,7 @@ sub checkMessage {
}
if ( $self->param('SAMLRequest') ) {
elsif ( $self->param('SAMLRequest') ) {
# Request in body part
$request = $self->param('SAMLRequest');
@ -370,7 +365,7 @@ sub checkMessage {
}
if ( $self->param('SAMLart') ) {
elsif ( $self->param('SAMLart') ) {
# Artifact in SAMLart param
$artifact = $self->param('SAMLart');
@ -1935,23 +1930,8 @@ sub getAuthnContext {
sub timestamp2samldate {
my ( $self, $timestamp ) = splice @_;
my ( $sec, $min, $hour, $mday, $mon, $year, $wday, $yday, $isdst ) =
gmtime($timestamp);
$year += 1900;
$mon++;
$mon = $mon > 9 ? $mon : "0" . $mon;
$mday = $mday > 9 ? $mday : "0" . $mday;
$hour = $hour > 9 ? $hour : "0" . $hour;
$min = $min > 9 ? $min : "0" . $min;
$sec = $sec > 9 ? $sec : "0" . $sec;
my $samldate = "$year-$mon-$mday" . "T" . "$hour:$min:$sec" . "Z";
$self->lmLog( "Convert timestamp $timestamp in SAML2 date: $samldate",
'debug' );
return $samldate;
my @t = gmtime($timestamp);
return strftime( "%Y-%m-%dT%R:%SZ", @t );
}
## @method string samldate2timestamp(string samldate)
@ -1980,11 +1960,7 @@ sub samldate2timestamp {
# @param $wait If true, do not call to autoRedirect or autoPost function
# @return boolean False if failed.
sub sendLogoutResponseToServiceProvider {
my $self = shift;
my $logout = shift;
my $method = shift;
my $relaystate = shift;
my $seconds = shift;
my ( $self, $logout, $method, $relaystate, $seconds ) = splice @_;
# Logout response
unless ( $self->buildLogoutResponseMsg($logout) ) {
@ -2017,7 +1993,7 @@ sub sendLogoutResponseToServiceProvider {
}
# HTTP-POST
if ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
# Use autosubmit form
my $slo_url = $logout->msg_url;
@ -2040,7 +2016,7 @@ sub sendLogoutResponseToServiceProvider {
}
# HTTP-SOAP
if ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
my $slo_body = $logout->msg_body;
$self->{SOAPMessage} = $slo_body;
@ -2071,11 +2047,7 @@ sub sendLogoutResponseToServiceProvider {
# @param $relay If SOAP method, build a relay logout request
# @return int Number of concerned providers.
sub sendLogoutRequestToServiceProvider {
my $self = shift;
my $logout = shift;
my $providerID = shift;
my $method = shift;
my $relay = shift;
my ( $self, $logout, $providerID, $method, $relay ) = splice @_;
my $server = $self->{_lassoServer};
my $info;
@ -2149,7 +2121,7 @@ sub sendLogoutRequestToServiceProvider {
}
# HTTP-POST
if ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_POST ) {
$self->lmLog( "Send POST logout request to $providerID", 'debug' );
@ -2169,7 +2141,7 @@ sub sendLogoutRequestToServiceProvider {
}
# HTTP-SOAP
if ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
elsif ( $method == Lasso::Constants::HTTP_METHOD_SOAP ) {
# Build a relay request, to be used after SLO process is done
if ($relay) {