/[cwmp]/google/trunk/lib/CWMP/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

Diff of /google/trunk/lib/CWMP/Server.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

google/lib/CWMP/Server.pm revision 83 by dpavlin, Fri Jun 22 15:54:43 2007 UTC google/trunk/lib/CWMP/Server.pm revision 150 by dpavlin, Sat Oct 27 22:53:14 2007 UTC
# Line 4  package CWMP::Server; Line 4  package CWMP::Server;
4  use strict;  use strict;
5  use warnings;  use warnings;
6    
   
7  use base qw/Class::Accessor/;  use base qw/Class::Accessor/;
8  __PACKAGE__->mk_accessors( qw/  __PACKAGE__->mk_accessors( qw/
9  port  port
10  store_path  store
11  default_queue  default_queue
12    background
13  debug  debug
14    
15    server
16  / );  / );
17    
18  use CWMP::Session;  use CWMP::Session;
# Line 28  CWMP::Server - description Line 30  CWMP::Server - description
30    
31    my $server = CWMP::Server->new({    my $server = CWMP::Server->new({
32          port => 3333,          port => 3333,
33          store_path => 'state.db',          store => 'state.db',
34          default_queue => [ qw/GetRPCMethods GetParameterNames/ ],                                                                    default_queue => [ qw/GetRPCMethods GetParameterNames/ ],                                                          
35            background => 1,
36          debug => 1          debug => 1
37    });    });
38    
# Line 41  Options: Line 44  Options:
44    
45  port to listen on  port to listen on
46    
47  =item store_path  =item store
48    
49  path to L<DBM::Deep> database file to preserve state  hash with key C<module> with value C<DBMDeep> if L<CWMP::Store::DBMDeep>
50    is used. Other parametars are optional.
51    
52  =item default_queue  =item default_queue
53    
# Line 59  sub new { Line 63  sub new {
63    
64          warn "created ", __PACKAGE__, "(", dump( @_ ), ") object\n" if $self->debug;          warn "created ", __PACKAGE__, "(", dump( @_ ), ") object\n" if $self->debug;
65    
66            warn "ACS waiting for request on port ", $self->port, "\n";
67    
68            $self->debug( 0 ) unless $self->debug;
69            warn "## debug level: ", $self->debug, "\n" if $self->debug;
70    
71            $self->server(
72                    CWMP::Server::Helper->new({
73                            proto => 'tcp',
74                            port => $self->port,
75                            default_queue => $self->default_queue,
76                            store => $self->store,
77                            debug => $self->debug,
78                            background => $self->background,
79                    })
80            );
81    
82          return $self;          return $self;
83  }  }
84    
85  =head2 run  =head2 run
86    
   $server->run();  
   
87  =cut  =cut
88    
89  sub run {  sub run {
90          my $self = shift;          my $self = shift;
91    
92          my $listen = IO::Socket::INET->new(          $self->server->run;
93                  Listen    => 5,  }
 #               LocalAddr => 'localhost',  
                 LocalPort => $self->port,  
                 Proto     => 'tcp',  
                 Blocking  => 1,  
                 ReuseAddr => 1,  
         );  
94    
95          warn "ACS waiting for request on port ", $self->port;  package CWMP::Server::Helper;
96    
97          $self->debug( 0 ) unless $self->debug;  use warnings;
98          warn "## debug level: ", $self->debug, "\n" if $self->debug;  use strict;
99    
100          warn $self->default_queue ? " queue ( " . join(",",@{$self->default_queue}) . " )" : "",  use base qw/Net::Server/;
101                  "\n";  use Carp qw/confess/;
102    use Data::Dump qw/dump/;
103    
104    sub options {
105            my $self     = shift;
106            my $prop     = $self->{'server'};
107            my $template = shift;
108    
109            ### setup options in the parent classes
110            $self->SUPER::options($template);
111    
112            # new single-value options
113            foreach my $p ( qw/ store debug / ) {
114                    $prop->{ $p } ||= undef;
115                    $template->{ $p } = \$prop->{ $p };
116            }
117    
118            # new multi-value options
119            foreach my $p ( qw/ default_queue / ) {
120                    $prop->{ $p } ||= [];
121                    $template->{ $p } = $prop->{ $p };
122            }
123    }
124    
125    
126    =head2 process_request
127    
128          while ( my $sock = $listen->accept ) {  =cut
129                  $sock->autoflush(1);  
130    sub process_request {
131            my $self = shift;
132    
133            my $prop = $self->{server};
134            confess "no server in ", ref( $self ) unless $prop;
135            my $sock = $prop->{client};
136            confess "no sock in ", ref( $self ) unless $sock;
137    
138            warn "default CPE queue ( " . join(",",@{$prop->{default_queue}}) . " )\n" if defined($prop->{default_queue});
139    
140            eval  {
141                  my $session = CWMP::Session->new({                  my $session = CWMP::Session->new({
142                          sock => $sock,                          sock => $sock,
143                          queue => $self->default_queue,                          queue => $prop->{default_queue},
144                          store_path => $self->store_path,                          store => $prop->{store},
145                          debug => $self->debug,                          debug => $prop->{debug},
146                  }) || confess "can't create session";                  }) || confess "can't create session";
147    
148                  while ( $session->process_request ) {                  while ( $session->process_request ) {
149                          warn "...another one bites the dust...\n";                          warn "...another one bites the dust...\n";
150                  }                  }
151            };
152    
153                  warn "...returning to accepting new connections\n";          if ($@) {
154                    warn $@;
155          }          }
156    
157            warn "...returning to accepting new connections\n";
158    
159  }  }
160    
161  1;  1;

Legend:
Removed from v.83  
changed lines
  Added in v.150

  ViewVC Help
Powered by ViewVC 1.1.26