ffzg/recall_notices.pl: added --interval and --dedup
[koha.git] / admin / sms_providers.pl
index bdc9349..c52a68e 100755 (executable)
@@ -26,33 +26,45 @@ use C4::Auth;
 use C4::Output;
 
 use Koha::SMS::Provider;
+use Koha::SMS::Providers;
 
 my $cgi = new CGI;
 
 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
-    {   template_name   => "admin/sms_providers.tt",
+    {
+        template_name   => "admin/sms_providers.tt",
         query           => $cgi,
         type            => "intranet",
         authnotrequired => 0,
-        flagsrequired   => { parameters => 'parameters_remaining_permissions' },
+        flagsrequired   => { parameters => 'manage_sms_providers' },
         debug           => 1,
     }
 );
 
-my $op     = $cgi->param('op');
+my $op     = $cgi->param('op') || '';
 my $id     = $cgi->param('id');
 my $name   = $cgi->param('name');
 my $domain = $cgi->param('domain');
 
 if ( $op eq 'add_update' ) {
     if ( $name && $domain ) {
-        Koha::SMS::Provider->new( { id => $id, name => $name, domain => $domain } )->store();
+        if ($id) {
+            my $provider = Koha::SMS::Providers->find($id);
+            $provider->set( { name => $name, domain => $domain } )->store()
+              if $provider;
+        }
+        else {
+            Koha::SMS::Provider->new( { name => $name, domain => $domain } )
+              ->store();
+        }
     }
-} elsif ( $op eq 'delete' ) {
-    Koha::SMS::Provider->find($id)->delete();
+}
+elsif ( $op eq 'delete' ) {
+    my $provider = Koha::SMS::Providers->find($id);
+    $provider->delete() if $provider;
 }
 
-my @providers = Koha::SMS::Provider->all();
+my @providers = Koha::SMS::Providers->search();
 
 $template->param( providers => \@providers );