diff Lib/IMPL/Web/QueryHandler/UrlController.pm @ 110:c13a215508ca

Refactoring, ControllerUnit
author wizard
date Mon, 17 May 2010 17:42:27 +0400 (2010-05-17)
parents Lib/IMPL/Web/QueryHandler/SecureCall.pm@964587c5183c
children 5a9f64890c31
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Lib/IMPL/Web/QueryHandler/UrlController.pm	Mon May 17 17:42:27 2010 +0400
@@ -0,0 +1,51 @@
+package IMPL::Web::QueryHandler::UrlController;
+use strict;
+use base qw(IMPL::Web::QueryHandler);
+
+use IMPL::Class::Property;
+use IMPL::Exception;
+use Carp;
+
+BEGIN {
+	public property namespace => prop_all;
+}
+
+__PACKAGE__->PassThroughArgs;
+
+sub Process {
+	my ($this,$action,$nextHandler) = @_;
+	
+	my $namespace = $this->namespace || $action->application->type;
+	
+	my @target = grep $_, split /\//, ($ENV{PATH_INFO} || '') or die new IMPL::Exception("No target specified");
+	
+	my $method = pop @target;
+	$method =~ s/\.\w+$//;
+	
+	my $module = join '::',$namespace,@target;
+	
+	eval "require $module; 1;" unless $INC{$module};
+	carp $@ if $@;
+	
+	if(UNIVERSAL::can($module,'InvokeAction')) {
+		$module->InvokeAction($method,$action);
+	} else {
+		die new IMPL::InvalidOperationException("Failed to invoke action",$ENV{PATH_INFO},$module,$method);
+	}
+}
+
+1;
+
+__END__
+
+=pod
+
+=head1 NAME
+
+C<IMPL::Web::QueryHandler::UrlController> - ����� ������ �� ������ <url> �������.
+
+=head1 DESCRIPTION
+
+���������� ���������� C<$ENV{PATH_INFO}> ��� ��������� ����� � ������ ������.
+
+=cut
\ No newline at end of file