use GetParameterValues to fetch 16 values at once
authorDobrica Pavlinusic <dpavlin@rot13.org>
Sun, 7 Mar 2010 17:58:29 +0000 (17:58 +0000)
committerDobrica Pavlinusic <dpavlin@rot13.org>
Sun, 7 Mar 2010 17:58:29 +0000 (17:58 +0000)
git-svn-id: https://perl-cwmp.googlecode.com/svn/trunk@259 836a5e1a-633d-0410-964b-294494ad4392

lib/CWMP/Session.pm

index 26b1358..bdde16c 100644 (file)
@@ -153,9 +153,24 @@ sub process_request {
                                }
                                $self->store->set_state( $uid, $stored );
                        } else {
                                }
                                $self->store->set_state( $uid, $stored );
                        } else {
-                               warn ">>> empty response $to_uid";
-                               $state->{NoMoreRequests} = 1;
-                               $xml = '';
+
+                               my @params = sort grep { ! exists $stored->{Parameter}->{$_} } grep { ! m/\.$/ } keys %{ $stored->{ParameterInfo} };
+                               if ( @params ) {
+                                       warn "# GetParameterValues ", dump( @params );
+                                       my $first = shift @params;
+                                       $xml = $self->dispatch( 'GetParameterValues', [ $first ] );
+                                       while ( @params ) {
+                                               my @chunk = splice @params, 0, 16; # FIXME 16 seems to be max
+                                               $queue->enqueue( 'GetParameterValues', [ @chunk ] );
+                                       }
+
+                               } else {
+
+                                       warn ">>> empty response $to_uid";
+                                       $state->{NoMoreRequests} = 1;
+                                       $xml = '';
+
+                               }
                        }
                }
        }
                        }
                }
        }