diff options
| author | Matthew Somerville <matthew-github@dracos.co.uk> | 2014-11-21 13:33:16 +0000 | 
|---|---|---|
| committer | Matthew Somerville <matthew-github@dracos.co.uk> | 2014-11-21 13:33:16 +0000 | 
| commit | 8ab1011021ca0736bb4b004437633a3a4545c5f5 (patch) | |
| tree | b7b6995ef84fb6cfad1e6d0c95363f93a5f191e1 | |
| parent | ea829cf5596513bbeb6868f652ae11324439ee82 (diff) | |
Better error if Open311 returns nil service list.
If an Open311 server responded with e.g. '<services></services>', you
got a strange hash error as the code treated it as one undef service.
Spot this at the same point we check anything was returned.
Also remove a couple of warnings due to lc of a maybe-undef variable.
| -rw-r--r-- | perllib/Open311/PopulateServiceList.pm | 18 | 
1 files changed, 10 insertions, 8 deletions
| diff --git a/perllib/Open311/PopulateServiceList.pm b/perllib/Open311/PopulateServiceList.pm index c47ab143d..0f6e32893 100644 --- a/perllib/Open311/PopulateServiceList.pm +++ b/perllib/Open311/PopulateServiceList.pm @@ -40,11 +40,11 @@ sub process_body {      $self->_check_endpoints;      my $list = $open311->get_service_list; -    unless ( $list ) { -        my $id = $self->_current_body->id; -        my $mapit_url = mySociety::Config::get('MAPIT_URL'); -        my $areas = join( ",", keys %{$self->_current_body->areas} ); +    unless ( $list && $list->{service} ) {          if ($self->verbose >= 1) { +            my $id = $self->_current_body->id; +            my $mapit_url = mySociety::Config::get('MAPIT_URL'); +            my $areas = join( ",", keys %{$self->_current_body->areas} );              warn "Body $id for areas $areas - $mapit_url/areas/$areas.html - did not return a service list\n";              warn $open311->error;          } @@ -156,9 +156,10 @@ sub _handle_existing_contact {          }      } -    if ( $contact and lc( $self->_current_service->{metadata} ) eq 'true' ) { +    my $metadata = $self->_current_service->{metadata} || ''; +    if ( $contact and lc($metadata) eq 'true' ) {          $self->_add_meta_to_contact( $contact ); -    } elsif ( $contact and $contact->extra and lc( $self->_current_service->{metadata} ) eq 'false' ) { +    } elsif ( $contact and $contact->extra and lc($metadata) eq 'false' ) {          $contact->update( { extra => undef } );      } @@ -192,7 +193,8 @@ sub _create_contact {          return;      } -    if ( $contact and lc( $self->_current_service->{metadata} ) eq 'true' ) { +    my $metadata = $self->_current_service->{metadata} || ''; +    if ( $contact and lc($metadata) eq 'true' ) {          $self->_add_meta_to_contact( $contact );      } @@ -205,7 +207,7 @@ sub _create_contact {  sub _add_meta_to_contact {      my ( $self, $contact ) = @_; -    print "Fetching meta data for $self->_current_service->{service_code}\n" if $self->verbose >= 2; +    print "Fetching meta data for " . $self->_current_service->{service_code} . "\n" if $self->verbose >= 2;      my $meta_data = $self->_current_open311->get_service_meta_info( $self->_current_service->{service_code} );      if ( ref $meta_data->{ attributes }->{ attribute } eq 'HASH' ) { | 
