/[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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 228 - (hide annotations)
Sun Nov 25 19:21:02 2007 UTC (16 years, 6 months ago) by dpavlin
File size: 2572 byte(s)
 r268@brr:  dpavlin | 2007-11-25 20:20:36 +0100
 - move to Net::Server::Fork
 - version [0.14]

1 dpavlin 83 # Dobrica Pavlinusic, <dpavlin@rot13.org> 06/22/07 14:35:38 CEST
2     package CWMP::Server;
3    
4     use strict;
5     use warnings;
6    
7     use base qw/Class::Accessor/;
8     __PACKAGE__->mk_accessors( qw/
9     port
10 dpavlin 205 session
11 dpavlin 84 background
12 dpavlin 83 debug
13 dpavlin 84
14     server
15 dpavlin 83 / );
16    
17     use CWMP::Session;
18 dpavlin 197 use CWMP::Queue;
19 dpavlin 83
20     use Carp qw/confess/;
21     use Data::Dump qw/dump/;
22    
23     =head1 NAME
24    
25     CWMP::Server - description
26    
27     =head1 METHODS
28    
29     =head2 new
30    
31     my $server = CWMP::Server->new({
32     port => 3333,
33 dpavlin 205 session => { ... },
34 dpavlin 84 background => 1,
35 dpavlin 83 debug => 1
36     });
37    
38     Options:
39    
40     =over 4
41    
42     =item port
43    
44     port to listen on
45    
46 dpavlin 205 =item session
47 dpavlin 83
48 dpavlin 150 hash with key C<module> with value C<DBMDeep> if L<CWMP::Store::DBMDeep>
49     is used. Other parametars are optional.
50 dpavlin 83
51     =back
52    
53     =cut
54    
55     sub new {
56     my $class = shift;
57     my $self = $class->SUPER::new( @_ );
58    
59     warn "created ", __PACKAGE__, "(", dump( @_ ), ") object\n" if $self->debug;
60    
61 dpavlin 84 warn "ACS waiting for request on port ", $self->port, "\n";
62    
63     $self->debug( 0 ) unless $self->debug;
64     warn "## debug level: ", $self->debug, "\n" if $self->debug;
65    
66     $self->server(
67     CWMP::Server::Helper->new({
68     proto => 'tcp',
69     port => $self->port,
70 dpavlin 205 session => $self->session,
71 dpavlin 84 debug => $self->debug,
72     background => $self->background,
73     })
74     );
75    
76 dpavlin 83 return $self;
77     }
78    
79     =head2 run
80    
81     =cut
82    
83     sub run {
84     my $self = shift;
85    
86 dpavlin 84 $self->server->run;
87     }
88 dpavlin 83
89 dpavlin 84 package CWMP::Server::Helper;
90 dpavlin 83
91 dpavlin 84 use warnings;
92     use strict;
93 dpavlin 83
94 dpavlin 228 #use base qw/Net::Server/;
95     use base qw/Net::Server::Fork/;
96 dpavlin 84 use Carp qw/confess/;
97     use Data::Dump qw/dump/;
98 dpavlin 83
99 dpavlin 84 sub options {
100     my $self = shift;
101     my $prop = $self->{'server'};
102     my $template = shift;
103 dpavlin 83
104 dpavlin 84 ### setup options in the parent classes
105     $self->SUPER::options($template);
106 dpavlin 83
107 dpavlin 84 # new single-value options
108 dpavlin 205 foreach my $p ( qw/ session debug / ) {
109 dpavlin 84 $prop->{ $p } ||= undef;
110     $template->{ $p } = \$prop->{ $p };
111     }
112 dpavlin 83
113 dpavlin 84 # new multi-value options
114 dpavlin 197 # foreach my $p ( qw/ default_queue / ) {
115     # $prop->{ $p } ||= [];
116     # $template->{ $p } = $prop->{ $p };
117     # }
118 dpavlin 83 }
119    
120 dpavlin 84
121     =head2 process_request
122    
123     =cut
124    
125     sub process_request {
126     my $self = shift;
127    
128     my $prop = $self->{server};
129     confess "no server in ", ref( $self ) unless $prop;
130     my $sock = $prop->{client};
131     confess "no sock in ", ref( $self ) unless $sock;
132    
133 dpavlin 205 my $sess = $prop->{session} || confess "no session";
134    
135 oleide 141 eval {
136 dpavlin 205 $sess->{sock} = $sock;
137     $sess->{debug} = $prop->{debug};
138 dpavlin 84
139 dpavlin 205 my $session = CWMP::Session->new( $sess ) || confess "can't create session from ",dump( $sess );
140    
141 oleide 141 while ( $session->process_request ) {
142 dpavlin 210 warn "...waiting for next request from CPE...\n" if $prop->{debug};
143 oleide 141 }
144     };
145    
146 dpavlin 205 warn "ERROR: $@\n" if $@;
147 dpavlin 84
148 dpavlin 210 warn "...returning to accepting new connections\n" if $prop->{debug};
149 dpavlin 84
150     }
151    
152 dpavlin 83 1;

  ViewVC Help
Powered by ViewVC 1.1.26