/[Frey]/branches/mojo/lib/Frey/Server.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

Contents of /branches/mojo/lib/Frey/Server.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 258 - (show annotations)
Tue Nov 4 20:26:59 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 4127 byte(s)
make Frey::Introspect default action if there is no
method specified in url, resulting in major reduction of
html everywhere which is nice
1 package Frey::Server;
2
3 use Moose;
4
5 with 'Frey::Web';
6
7 use Continuity;
8 #use Continuity::REPL;
9 use Data::Dump qw/dump/;
10
11 #use Carp::REPL; ## XXX it would be nice, but it breaks error reporting too much
12 use Frey::ClassLoader;
13 use Frey::Run;
14
15 my @messages; # Global (shared) list of messages
16 my $got_message; # Flag to indicate that there is a new message to display
17
18 use vars qw( $repl $server );
19
20 #$repl = Continuity::REPL->new;
21
22 =head1 NAME
23
24 Frey::Server - Continuity based server for Frey
25
26 =head2 DESCRIPTION
27
28 This is one of pissible server implementations for Frey. In it's current stage, it's also most complete one.
29
30 =head2 run
31
32 $o->run( $optional_port );
33
34 =cut
35
36 sub run {
37 my ( $self, $port ) = @_;
38 $server = Continuity->new(
39 port => $port || 16001,
40 path_session => 1,
41 cookie_session => 'sid',
42 callback => \&main,
43 debug_level => 2,
44 staticp => sub { $_[0]->url =~ m/\.(jpg|jpeg|gif|png|css|ico|js|html?|xml|json|ya?ml)(\?.*)?$/ },
45 );
46 $Module::Reload::Debug = 1; # auto if debug_level > 1
47 Frey::ClassLoader->new->load_all_classes();
48 $server->loop;
49 }
50
51 =head2 main
52
53 This is simple dispatcher for our server. Currently it's in flux and
54 documented only in source code.
55
56 =cut
57
58 sub main {
59 my ($req) = @_;
60
61 my $path = $req->request->url->path;
62 #warn "REQUEST: $path ",dump( $req->params );
63
64 Module::Reload->check if $path =~ m!reload! || $req->param('reload');
65
66 # warn $req->request->header('User_Agent');
67
68 my %params = $req->params;
69 my $html;
70
71 sub rest2class {
72 my $class = shift;
73 $class =~ s/-/::/; # sigh!
74 return $class;
75 }
76
77
78 eval {
79
80 my $f;
81
82 my $run_regexp = join('|', Frey::Run->execute );
83
84 if (
85 $path =~ m{/Frey[:-]+ObjectBrowser}
86 ) {
87 $f = Frey::ObjectBrowser->new( fey_class => $params{class} );
88 $f->request( $req );
89 } elsif (
90 $path =~ m{/Frey[:-]+ObjectDesigner}
91 ) {
92 $f = Frey::ObjectDesigner->new( fey_class => $params{class} );
93 $f->request( $req );
94 } elsif (
95 $path =~ m{/([^/]+)/($run_regexp)}
96 ) {
97 my $class = rest2class $1;
98 warn "# run $class $2\n";
99 $f = Frey::Run->new( class => $class, params => \%params );
100 } elsif (
101 $path =~ m{/([^/]+)/?$}
102 ) {
103 my $class = rest2class $1;
104 warn "# introspect $class";
105 $f = Frey::Run->new( class => 'Frey::Introspect', params => { class => $class } );
106 } else {
107 $f = Frey::Run->new( class => 'Frey::ClassBrowser' );
108 }
109
110 if ( $f ) {
111 $req->print( $f->html );
112 } else {
113 warn "# can't call request on nothing!";
114 }
115
116 };
117
118 my $self = $req;
119
120 if ( $@ ) {
121 warn $@;
122 $req->conn->send_error( 404 ); # FIXME this should probably be 500, but we can't ship page with it
123 $req->print( qq{<pre class="error">$@<pre>} );
124 # Carp::REPL::repl;
125
126 }
127
128 # If this is a request for the pushtream, then give them that
129 if($path =~ /pushstream/) {
130 pushstream($req);
131 }
132
133 # If they are sending us a message, we give them a thread for that too
134 if($path =~ /sendmessage/) {
135 send_message($req);
136 }
137
138 }
139
140 # Here we accept a connection to the browser, and keep it open. Meanwhile we
141 # watch the global $got_message variable, and when it gets touched we send off
142 # the list of messages through the held-open connection. Then we let the
143 # browser open a new connection and begin again.
144 sub pushstream {
145 my ($req) = @_;
146 # Set up watch event -- this will be triggered when $got_message is written
147 my $w = Coro::Event->var(var => \$got_message, poll => 'w');
148 while(1) {
149 print STDERR "**** GOT MESSAGE, SENDING ****\n";
150 my $log = join "<br>", @messages;
151 $req->print($log);
152 $req->next;
153 print STDERR "**** Waiting for got_message indicator ****\n";
154 $w->next;
155 }
156 }
157
158
159 # Watch for the user to send us a message. As soon as we get it, we add it to
160 # our list of messages and touch the $got_message flag to let all the
161 # pushstreams know.
162 sub send_message {
163 my ($req) = @_;
164 while(1) {
165 my $msg = $req->param('message');
166 my $name = $req->param('username');
167 if($msg) {
168 unshift @messages, "$name: $msg";
169 pop @messages if $#messages > 15; # Only keep the recent 15 messages
170 }
171 $got_message = 1;
172 $req->print("Got it!");
173 $req->next;
174 }
175 }
176
177 1;

  ViewVC Help
Powered by ViewVC 1.1.26