/[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 56 - (show annotations)
Sun Jul 6 11:59:58 2008 UTC (15 years, 9 months ago) by dpavlin
File size: 2891 byte(s)
more work on server-size class browser

- correct loading of modules
- display required attributes
1 package Frey::Server;
2
3 use Moose;
4
5 use Continuity;
6 #use Continuity::REPL;
7 use Continuity::Widget::DomNode;
8 use Data::Dump qw/dump/;
9
10 use Frey;
11 use Frey::Introspect;
12
13 my @messages; # Global (shared) list of messages
14 my $got_message; # Flag to indicate that there is a new message to display
15
16 use vars qw( $repl $server );
17
18 #$repl = Continuity::REPL->new;
19 $server = Continuity->new(
20 port => 16001,
21 path_session => 1,
22 cookie_session => 'sid',
23 callback => \&main,
24 debug_level => 1,
25 staticp => sub { $_[0]->url =~ m/\.(jpg|jpeg|gif|png|css|ico|js|html?)$/ },
26 );
27
28 sub run {
29 $server->loop;
30 }
31
32 # This is the main entrypoint. We are looking for one of three things -- a
33 # pushstream, a sent message, or a request for the main HTML. We delegate each
34 # of these cases, none of which will return (they all loop forever).
35 sub main {
36 my ($req) = @_;
37
38 my $path = $req->request->url->path;
39 warn "REQUEST: $path\n";
40
41 warn $req->request->header('User_Agent');
42 #warn dump( $req );
43
44 if ( $path =~ m!/~/([^/]+)(?:/([^/]*))?! ) {
45 my $f = Frey::Introspect->new( package => $1 );
46 $f->html( $req );
47 }
48
49 # If this is a request for the pushtream, then give them that
50 if($path =~ /pushstream/) {
51 pushstream($req);
52 }
53
54 # If they are sending us a message, we give them a thread for that too
55 if($path =~ /sendmessage/) {
56 send_message($req);
57 }
58
59 while ( 1 ) {
60 my $f = Frey->new;
61 my $classes = Continuity::Widget::DomNode->create(
62 ul => [
63 map {
64 warn dump( $_ );
65 my ( $package, $path ) = %$_;
66 ( li => [ a => { href => '/~/' . $package . '/' } => [ $package ], " <tt>$path</tt>" ] )
67 } @{ $f->classes }
68 ],
69 )->to_string;
70 $req->print( $classes );
71 $req->next;
72 }
73 }
74
75 # Here we accept a connection to the browser, and keep it open. Meanwhile we
76 # watch the global $got_message variable, and when it gets touched we send off
77 # the list of messages through the held-open connection. Then we let the
78 # browser open a new connection and begin again.
79 sub pushstream {
80 my ($req) = @_;
81 # Set up watch event -- this will be triggered when $got_message is written
82 my $w = Coro::Event->var(var => \$got_message, poll => 'w');
83 while(1) {
84 print STDERR "**** GOT MESSAGE, SENDING ****\n";
85 my $log = join "<br>", @messages;
86 $req->print($log);
87 $req->next;
88 print STDERR "**** Waiting for got_message indicator ****\n";
89 $w->next;
90 }
91 }
92
93
94 # Watch for the user to send us a message. As soon as we get it, we add it to
95 # our list of messages and touch the $got_message flag to let all the
96 # pushstreams know.
97 sub send_message {
98 my ($req) = @_;
99 while(1) {
100 my $msg = $req->param('message');
101 my $name = $req->param('username');
102 if($msg) {
103 unshift @messages, "$name: $msg";
104 pop @messages if $#messages > 15; # Only keep the recent 15 messages
105 }
106 $got_message = 1;
107 $req->print("Got it!");
108 $req->next;
109 }
110 }
111
112 1;

  ViewVC Help
Powered by ViewVC 1.1.26