/[SQLSession]/trunk/lib/SQLSession/Dispatcher.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Annotation of /trunk/lib/SQLSession/Dispatcher.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 78 - (hide annotations)
Mon Jan 29 20:11:20 2007 UTC (17 years, 2 months ago) by dpavlin
File size: 1427 byte(s)
re-organize SQL query page into fragments
1 dpavlin 20 package SQLSession::Dispatcher;
2    
3     use strict;
4     use warnings;
5    
6     use Jifty::Dispatcher -base;
7    
8     use Data::Dump qw/dump/;
9    
10 dpavlin 33 before '*' => run {
11     my $top = Jifty->web->navigation;
12 dpavlin 58 my $edit = Jifty->web->current_user->role('edit');
13 dpavlin 33 $top->child( 'New' => url => '/new' ) if ($edit);
14 dpavlin 40 my $l = $top->child( 'List' => url => '/list' );
15    
16     my $databases = SQLSession::Model::DatabaseCollection->new();
17     $databases->unlimit;
18     while ( my $db = $databases->next ) {
19     my $label = $db->name;
20     # $label .= ' [' . $db->dsn . ']' if ($edit);
21 dpavlin 49 my $url = '/list/database/' . $db->id;
22     my $path = Jifty->web->request->path;
23 dpavlin 57 # warn "url: $url path: $path\n";
24 dpavlin 49 $l->child( $label => url => $url => active => ( $url eq $path ) );
25 dpavlin 40 }
26    
27 dpavlin 46 if ( Jifty->web->current_user->id ) {
28     $top->child( 'Logout' => url => '/logout' );
29     } else {
30     $top->child( 'Login' => url => '/login' );
31     $top->child( 'Signup' => url => '/signup' );
32     }
33    
34 dpavlin 58 if ( Jifty->web->current_user->role( 'admin' ) ) {
35     $top->child( 'Docs' => url => '/__jifty/online_docs/' );
36     $top->child( 'Administration' => url => '/__jifty/admin/' );
37     }
38    
39 dpavlin 33 };
40    
41    
42 dpavlin 20 under qr{sql/(\d+)} => run {
43    
44     my $q = SQLSession::Model::Query->new();
45     $q->load( $1 ) or next_rule;
46    
47 dpavlin 75 # warn "q = ",dump( $q );
48 dpavlin 20
49 dpavlin 78 set q => $q;
50 dpavlin 20
51 dpavlin 22 show '/sql';
52 dpavlin 20
53     };
54    
55 dpavlin 39 under 'list' => [
56    
57     on qr{database/(\d+)} => run {
58     set database_id => $1;
59     },
60    
61     show '/list',
62     ];
63    
64 dpavlin 22 on 'new' => run {
65     show '/sql';
66 dpavlin 21 };
67    
68 dpavlin 22 on '/' => run {
69 dpavlin 28 redirect '/list';
70 dpavlin 22 };
71    
72 dpavlin 20 1;

  ViewVC Help
Powered by ViewVC 1.1.26