# HG changeset patch # User wizard # Date 1275280239 -14400 # Node ID 1722ca51537cdb1483fd5fbf0de991b58eba8db9 # Parent 5edc2ac5231cf27655528cd92417c711c29e7708 minor changes. Auth no more throws an exception when fails diff -r 5edc2ac5231c -r 1722ca51537c Lib/IMPL/DOM/Node.pm --- a/Lib/IMPL/DOM/Node.pm Wed May 26 02:32:22 2010 +0400 +++ b/Lib/IMPL/DOM/Node.pm Mon May 31 08:30:39 2010 +0400 @@ -19,6 +19,8 @@ public _direct property childNodes => { get => \&_getChildNodes }; # prop_list public _direct property parentNode => prop_get ; private _direct property _propertyMap => prop_all ; + + __PACKAGE__->class_data(property_bind => {}); } our %Axes = ( diff -r 5edc2ac5231c -r 1722ca51537c Lib/IMPL/Web/QueryHandler/PageFormat.pm --- a/Lib/IMPL/Web/QueryHandler/PageFormat.pm Wed May 26 02:32:22 2010 +0400 +++ b/Lib/IMPL/Web/QueryHandler/PageFormat.pm Mon May 31 08:30:39 2010 +0400 @@ -13,6 +13,7 @@ public property templatesCharset => prop_all; public property templatesBase => prop_all; public property defaultTarget => prop_all; + public property pathinfoPrefix => prop_all; } sub CTOR { @@ -31,17 +32,22 @@ $this->templatesBase($ENV{DOCUMENT_ROOT}) unless $this->templatesBase; my $pathInfo = $ENV{PATH_INFO}; - local $ENV{PATH_INFO} = $pathInfo || $this->defaultTarget; + my $prefixRoot = ""; + if (my $rx = $this->pathinfoPrefix) { + $pathInfo =~ s/($rx)//; + $prefixRoot = $1 if $1; + } + local $ENV{PATH_INFO} = $pathInfo || $this->defaultTarget; my @path = split /\//, ($ENV{PATH_INFO} || '') or die new IMPL::Exception("PATH_INFO is empty and no defaultTarget specified" ); $doc->LoadFile ( File::Spec->catfile($this->templatesBase,@path), $this->templatesCharset ); $doc->AddVar( result => $nextHandler->() ); - $doc->AddVar( absoluteUrl => sub { "/$_[0]" } ); + $doc->AddVar( absoluteUrl => sub { "$prefixRoot/$_[0]" } ); { local $@; - $doc->AddVar( user => eval { IMPL::Security::Context->current->principal; } ); - $doc->AddVar( session => eval { IMPL::Security::Context->current; } ); + $doc->AddVar( user => IMPL::Security::Context->current->principal ); + $doc->AddVar( session => IMPL::Security::Context->current ); warn $@ if $@; } diff -r 5edc2ac5231c -r 1722ca51537c Lib/IMPL/Web/Security.pm --- a/Lib/IMPL/Web/Security.pm Wed May 26 02:32:22 2010 +0400 +++ b/Lib/IMPL/Web/Security.pm Mon May 31 08:30:39 2010 +0400 @@ -35,10 +35,6 @@ my ($status,$answer) = $auth->DoAuth($challenge); - if ($status == AUTH_FAIL) { - die new IMPL::SecurityException("Authentication failed","DoAuth failed"); - } - return { status => $status, answer => $answer,