/[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 119 - (show annotations)
Sun Jul 13 18:51:29 2008 UTC (15 years, 9 months ago) by dpavlin
File size: 3189 byte(s)
split ClassBrowser into it's own package (class)
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;
12 use Frey::ClassLoader;
13
14 my @messages; # Global (shared) list of messages
15 my $got_message; # Flag to indicate that there is a new message to display
16
17 use vars qw( $repl $server );
18
19 #$repl = Continuity::REPL->new;
20
21 sub run {
22 my ( $self, $port ) = @_;
23 $server = Continuity->new(
24 port => $port || 16001,
25 path_session => 1,
26 cookie_session => 'sid',
27 callback => \&main,
28 debug_level => 1,
29 staticp => sub { $_[0]->url =~ m/\.(jpg|jpeg|gif|png|css|ico|js|html?)$/ },
30 );
31 $Module::Reload::Debug = 1;
32 Frey::ClassLoader->new->load_all_classes();
33 $server->loop;
34 }
35
36 # This is the main entrypoint. We are looking for one of three things -- a
37 # pushstream, a sent message, or a request for the main HTML. We delegate each
38 # of these cases, none of which will return (they all loop forever).
39 sub main {
40 my ($req) = @_;
41
42 my $path = $req->request->url->path;
43 warn "REQUEST: $path\n";
44
45 warn $req->request->header('User_Agent');
46 #warn dump( $req );
47
48 eval {
49
50 my $f;
51
52 if ( $path =~ m!/~/([^/]+)(.*)! ) {
53 $f = Frey::Introspect->new( package => $1 );
54 } elsif ( $path =~ m!/ob/([^/]+)(.*)! ) {
55 $f = Frey::ObjectBrowser->new( fey_class => $1 );
56 } elsif ( $path =~ m!/od/([^/]+)(.*)! ) {
57 $f = Frey::ObjectDesigner->new( fey_class => $1 );
58 }
59 $f->html( $req ) if $f;
60
61 };
62
63 if ( $@ ) {
64 warn $@;
65 #$req->conn->send_error( 404 ); # FIXME this should probably be 500, but we can't ship page with it
66 $req->print( qq{<pre class="error">$@<pre>} );
67 # Carp::REPL::repl; # FIXME if $self->debug
68 } else {
69
70 $req->print(
71 "<h1>Classes</h1>" .
72 Frey::ClassBrowser->new->html_markup
73 );
74
75 }
76
77 # If this is a request for the pushtream, then give them that
78 if($path =~ /pushstream/) {
79 pushstream($req);
80 }
81
82 # If they are sending us a message, we give them a thread for that too
83 if($path =~ /sendmessage/) {
84 send_message($req);
85 }
86
87 }
88
89 # Here we accept a connection to the browser, and keep it open. Meanwhile we
90 # watch the global $got_message variable, and when it gets touched we send off
91 # the list of messages through the held-open connection. Then we let the
92 # browser open a new connection and begin again.
93 sub pushstream {
94 my ($req) = @_;
95 # Set up watch event -- this will be triggered when $got_message is written
96 my $w = Coro::Event->var(var => \$got_message, poll => 'w');
97 while(1) {
98 print STDERR "**** GOT MESSAGE, SENDING ****\n";
99 my $log = join "<br>", @messages;
100 $req->print($log);
101 $req->next;
102 print STDERR "**** Waiting for got_message indicator ****\n";
103 $w->next;
104 }
105 }
106
107
108 # Watch for the user to send us a message. As soon as we get it, we add it to
109 # our list of messages and touch the $got_message flag to let all the
110 # pushstreams know.
111 sub send_message {
112 my ($req) = @_;
113 while(1) {
114 my $msg = $req->param('message');
115 my $name = $req->param('username');
116 if($msg) {
117 unshift @messages, "$name: $msg";
118 pop @messages if $#messages > 15; # Only keep the recent 15 messages
119 }
120 $got_message = 1;
121 $req->print("Got it!");
122 $req->next;
123 }
124 }
125
126 1;

  ViewVC Help
Powered by ViewVC 1.1.26