/[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 243 - (show annotations)
Sun Nov 2 21:24:04 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 3942 byte(s)
a swipe of refactoring to run under Mojo and Continuity with same REST API

- all objects are now invoked using URL path as object name and param
  (which doesn't work with Mojo as of this commit)
- Frey::Run is now usable Moose object for both servers
- move handling of Continuity bits into Frey::Server only
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 eval {
72
73 my $f;
74
75 my $run_regexp = join('|', Frey::Run->execute );
76
77 if ( $path =~ m!/Frey[:-]+ObjectBrowser! ) {
78 $f = Frey::ObjectBrowser->new( fey_class => $params{class} );
79 $f->request( $req );
80 } elsif ( $path =~ m!/Frey[:-]+ObjectDesigner! ) {
81 $f = Frey::ObjectDesigner->new( fey_class => $params{class} );
82 $f->request( $req );
83 } elsif ( $path =~ m!/Frey[:-]+Introspect! ) {
84 $f = Frey::Introspect->new( class => $params{class} );
85 $req->print( $f->markup );
86 undef $f;
87 } elsif ( $path =~ m!/([^/]+)/($run_regexp)! ) {
88 warn "# run $1 $2\n";
89 $f = Frey::Run->new( class => $1, params => \%params );
90 } else {
91 $f = Frey::Run->new( class => 'Frey::ClassBrowser' );
92 }
93
94 if ( $f ) {
95 $req->print( $f->html );
96 } else {
97 warn "# can't call request on nothing!";
98 }
99
100 };
101
102 my $self = $req;
103
104 if ( $@ ) {
105 warn $@;
106 $req->conn->send_error( 404 ); # FIXME this should probably be 500, but we can't ship page with it
107 $req->print( qq{<pre class="error">$@<pre>} );
108 # Carp::REPL::repl;
109
110 }
111
112 # If this is a request for the pushtream, then give them that
113 if($path =~ /pushstream/) {
114 pushstream($req);
115 }
116
117 # If they are sending us a message, we give them a thread for that too
118 if($path =~ /sendmessage/) {
119 send_message($req);
120 }
121
122 }
123
124 # Here we accept a connection to the browser, and keep it open. Meanwhile we
125 # watch the global $got_message variable, and when it gets touched we send off
126 # the list of messages through the held-open connection. Then we let the
127 # browser open a new connection and begin again.
128 sub pushstream {
129 my ($req) = @_;
130 # Set up watch event -- this will be triggered when $got_message is written
131 my $w = Coro::Event->var(var => \$got_message, poll => 'w');
132 while(1) {
133 print STDERR "**** GOT MESSAGE, SENDING ****\n";
134 my $log = join "<br>", @messages;
135 $req->print($log);
136 $req->next;
137 print STDERR "**** Waiting for got_message indicator ****\n";
138 $w->next;
139 }
140 }
141
142
143 # Watch for the user to send us a message. As soon as we get it, we add it to
144 # our list of messages and touch the $got_message flag to let all the
145 # pushstreams know.
146 sub send_message {
147 my ($req) = @_;
148 while(1) {
149 my $msg = $req->param('message');
150 my $name = $req->param('username');
151 if($msg) {
152 unshift @messages, "$name: $msg";
153 pop @messages if $#messages > 15; # Only keep the recent 15 messages
154 }
155 $got_message = 1;
156 $req->print("Got it!");
157 $req->next;
158 }
159 }
160
161 1;

  ViewVC Help
Powered by ViewVC 1.1.26