/[Frey]/trunk/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 /trunk/lib/Frey/Server.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 223 - (show annotations)
Sat Nov 1 00:14:05 2008 UTC (15 years, 6 months ago) by dpavlin
File size: 3669 byte(s)
refactor callback types into Frey::Run [0.17]
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 # eval {
69 {
70
71 my $f;
72
73 my $run_regexp = join('|', Frey::Run->execute );
74
75 if ( $path =~ m!/~/([^/]+)(.*)! ) {
76 $f = Frey::Introspect->new( package => $1 );
77 } elsif ( $path =~ m!/ob/([^/]+)(.*)! ) {
78 $f = Frey::ObjectBrowser->new( fey_class => $1 );
79 } elsif ( $path =~ m!/od/([^/]+)(.*)! ) {
80 $f = Frey::ObjectDesigner->new( fey_class => $1 );
81 } elsif ( $path =~ m!/($run_regexp)/([^/]+)(.*)! ) {
82 warn "# run $1 $2\n";
83 $f = Frey::Run->new( class => $2 );
84 } else {
85 $f = Frey::Run->new( class => 'Frey::ClassBrowser' );
86 }
87 $f->request( $req ) if $f;
88
89 };
90
91 my $self = $req;
92
93 if ( $@ ) {
94 warn $@;
95 $req->conn->send_error( 404 ); # FIXME this should probably be 500, but we can't ship page with it
96 $req->print( qq{<pre class="error">$@<pre>} );
97 # Carp::REPL::repl;
98
99 }
100
101 # If this is a request for the pushtream, then give them that
102 if($path =~ /pushstream/) {
103 pushstream($req);
104 }
105
106 # If they are sending us a message, we give them a thread for that too
107 if($path =~ /sendmessage/) {
108 send_message($req);
109 }
110
111 }
112
113 # Here we accept a connection to the browser, and keep it open. Meanwhile we
114 # watch the global $got_message variable, and when it gets touched we send off
115 # the list of messages through the held-open connection. Then we let the
116 # browser open a new connection and begin again.
117 sub pushstream {
118 my ($req) = @_;
119 # Set up watch event -- this will be triggered when $got_message is written
120 my $w = Coro::Event->var(var => \$got_message, poll => 'w');
121 while(1) {
122 print STDERR "**** GOT MESSAGE, SENDING ****\n";
123 my $log = join "<br>", @messages;
124 $req->print($log);
125 $req->next;
126 print STDERR "**** Waiting for got_message indicator ****\n";
127 $w->next;
128 }
129 }
130
131
132 # Watch for the user to send us a message. As soon as we get it, we add it to
133 # our list of messages and touch the $got_message flag to let all the
134 # pushstreams know.
135 sub send_message {
136 my ($req) = @_;
137 while(1) {
138 my $msg = $req->param('message');
139 my $name = $req->param('username');
140 if($msg) {
141 unshift @messages, "$name: $msg";
142 pop @messages if $#messages > 15; # Only keep the recent 15 messages
143 }
144 $got_message = 1;
145 $req->print("Got it!");
146 $req->next;
147 }
148 }
149
150 1;

  ViewVC Help
Powered by ViewVC 1.1.26