diff options
| author | Dave Arter <davea@mysociety.org> | 2017-04-07 14:07:08 +0100 | 
|---|---|---|
| committer | Dave Arter <davea@mysociety.org> | 2017-04-10 14:21:54 +0100 | 
| commit | 430f17de7b4af94e52152bf11a30bd423a7a1c34 (patch) | |
| tree | 1a59ed076561b34d8c018bc845a0183f4b64f3a4 | |
| parent | 880acad342b69720fe7acd54e0e7cede7036e4c7 (diff) | |
Allow comma-separated contact emails in the admin
The report-sending code has allowed multiple emails for a long time, but the
admin wouldn't allow you to enter multiple emails for each contact.
Fixes mysociety/FixMyStreet-Commercial#835
| m--------- | commonlib | 0 | ||||
| -rw-r--r-- | perllib/FixMyStreet/App/Controller/Admin.pm | 7 | ||||
| -rw-r--r-- | t/app/controller/admin.t | 15 | 
3 files changed, 17 insertions, 5 deletions
| diff --git a/commonlib b/commonlib -Subproject 4d1ca3580a9eebc56e2e4ef800fdb45a8e2e397 +Subproject cb9fd0029879d301f331e08c28aa287e504b2a2 diff --git a/perllib/FixMyStreet/App/Controller/Admin.pm b/perllib/FixMyStreet/App/Controller/Admin.pm index d37e0b39c..c49cafe7d 100644 --- a/perllib/FixMyStreet/App/Controller/Admin.pm +++ b/perllib/FixMyStreet/App/Controller/Admin.pm @@ -7,7 +7,7 @@ BEGIN { extends 'Catalyst::Controller'; }  use Path::Class;  use POSIX qw(strftime strcoll);  use Digest::SHA qw(sha1_hex); -use mySociety::EmailUtil qw(is_valid_email); +use mySociety::EmailUtil qw(is_valid_email is_valid_email_list);  use mySociety::ArrayUtils;  use DateTime::Format::Strptime;  use List::Util 'first'; @@ -357,10 +357,11 @@ sub update_contacts : Private {              }          ); -        my $email = $self->trim( $c->get_param('email') ); +        my $email = $c->get_param('email'); +        $email =~ s/\s+//g;          my $send_method = $c->get_param('send_method') || $contact->send_method || $contact->body->send_method || "";          unless ( $send_method eq 'Open311' ) { -            $errors{email} = _('Please enter a valid email') unless is_valid_email($email) || $email eq 'REFUSED'; +            $errors{email} = _('Please enter a valid email') unless is_valid_email_list($email) || $email eq 'REFUSED';          }          $contact->email( $email ); diff --git a/t/app/controller/admin.t b/t/app/controller/admin.t index 2fdd8b74a..5f8abe5a6 100644 --- a/t/app/controller/admin.t +++ b/t/app/controller/admin.t @@ -206,7 +206,7 @@ subtest 'check contact creation' => sub {  subtest 'check contact editing' => sub {      $mech->get_ok('/admin/body/' . $body->id .'/test%20category'); -    $mech->submit_form_ok( { with_fields => {  +    $mech->submit_form_ok( { with_fields => {          email    => 'test2@example.com',          note     => 'test2 note',          non_public => undef, @@ -218,7 +218,18 @@ subtest 'check contact editing' => sub {      $mech->content_contains( 'Private: No' );      $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); -    $mech->submit_form_ok( { with_fields => {  +    $mech->submit_form_ok( { with_fields => { +        email    => 'test2@example.com, test3@example.com', +        note     => 'test3 note', +    } } ); + +    $mech->content_contains( 'test2@example.com,test3@example.com' ); + +    $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); +    $mech->content_contains( '<td><strong>test2@example.com,test3@example.com' ); + +    $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); +    $mech->submit_form_ok( { with_fields => {          email    => 'test2@example.com',          note     => 'test2 note',          non_public => 'on', | 
