You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							449 lines
						
					
					
						
							15 KiB
						
					
					
				
			
		
		
	
	
							449 lines
						
					
					
						
							15 KiB
						
					
					
				| package NGCP::Panel::Controller::EmailTemplate;
 | |
| use NGCP::Panel::Utils::Generic qw(:all);
 | |
| use Sipwise::Base;
 | |
| 
 | |
| use parent 'Catalyst::Controller';
 | |
| 
 | |
| use NGCP::Panel::Form;
 | |
| 
 | |
| use NGCP::Panel::Utils::Email;
 | |
| use NGCP::Panel::Utils::Message;
 | |
| use JSON qw/encode_json decode_json/;
 | |
| 
 | |
| sub auto :Private {
 | |
|     my ($self, $c) = @_;
 | |
|     $c->log->debug(__PACKAGE__ . '::auto');
 | |
|     NGCP::Panel::Utils::Navigation::check_redirect_chain(c => $c);
 | |
| 
 | |
|     $c->stash(template => 'emailtemplate/test.tt');
 | |
| 
 | |
| }
 | |
| 
 | |
| sub tmpl_list :Chained('/') :PathPart('emailtemplate') :CaptureArgs(0) :Does(ACL) :ACLDetachTo('/denied_page') :AllowedRole(admin) :AllowedRole(reseller) :AllowedRole(ccareadmin) :AllowedRole(ccare) {
 | |
|     my ( $self, $c ) = @_;
 | |
| 
 | |
|     my $tmpl_rs = $c->model('DB')->resultset('email_templates');
 | |
|     $c->stash->{template_dt_columns} = NGCP::Panel::Utils::Datatables::set_columns($c, [
 | |
|         { name => 'id', search => 1, title => $c->loc('#') },
 | |
|         { name => 'reseller.name', search => 1, title => $c->loc('Reseller') },
 | |
|         { name => 'name', search => 1, title => $c->loc('Name') },
 | |
|         { name => 'from_email', search => 1, title => $c->loc('From') },
 | |
|         { name => 'subject', search => 1, title => $c->loc('Subject') },
 | |
|     ]);
 | |
| 
 | |
|     #select r.id as reseller_id,r.name as reseller_name, etd.id as email_template_id, etd.name as email_template_name from resellers r
 | |
|     #join email_templates etd on etd.reseller_id is null
 | |
|     #left join email_templates et on et.name=etd.name and et.reseller_id=r.id
 | |
|     #where r.status != 'terminated' and et.id is null order by r.id,etd.id;
 | |
|     my $tmpl_missed_rs = $c->model('DB')->resultset('resellers')->search_rs({
 | |
|             'et.id' => undef,
 | |
|             'me.status' => { '!=' => 'terminated' },
 | |
|         },{
 | |
|             'select' => [
 | |
|                 { '' => \'concat(me.id,"/",etd.id)', -as => 'id' },
 | |
|                 { '' => \['me.id'],    -as => 'reseller_id' },
 | |
|                 { '' => \['me.name'],  -as => 'reseller_name' },
 | |
|                 { '' => \['etd.id'],   -as => 'email_template_id' },
 | |
|                 { '' => \['etd.name'], -as => 'email_template_name' },
 | |
|             ],
 | |
|             'as'     => [qw/id reseller_id reseller_name email_template_id email_template_name/],
 | |
|             alias => 'me',
 | |
|             order_by => [qw/reseller_id email_template_id/],
 | |
|             from  => [
 | |
|                 { 'me' => 'billing.resellers' },
 | |
|                 [
 | |
|                     { 'etd' => 'billing.email_templates' },
 | |
|                     [
 | |
|                         { 'etd.reseller_id' => { -value => undef } },
 | |
|                     ],
 | |
|                 ],
 | |
|                 [
 | |
|                     { 'et' => 'billing.email_templates', '-join_type' => 'left' },
 | |
|                     [
 | |
|                         {
 | |
|                             '-and' => [
 | |
|                                 {
 | |
|                                     'et.name'        => { '-ident' => 'etd.name'} ,
 | |
|                                     'et.reseller_id' => { '-ident' => 'me.id'} ,
 | |
|                                 },
 | |
|                             ],
 | |
|                         },
 | |
|                     ],
 | |
|                 ],
 | |
|             ],
 | |
|         }
 | |
|     );
 | |
|     if($c->user->roles eq "admin") {
 | |
|     } elsif($c->user->roles eq "reseller") {
 | |
|         $tmpl_rs = $tmpl_rs->search({
 | |
|             reseller_id => $c->user->reseller_id,
 | |
|         });
 | |
|         $tmpl_missed_rs = $tmpl_missed_rs->search_rs({ 'me.id' => $c->user->reseller_id });
 | |
|     }
 | |
| 
 | |
|     $c->stash->{tmpl_rs} = $tmpl_rs;
 | |
|     $c->stash->{tmpl_missed_rs} = $tmpl_missed_rs;
 | |
| 
 | |
|     $c->stash->{email_template_external_filter} = $c->session->{email_template_external_filter};
 | |
| 
 | |
|     $c->stash(template => 'emailtemplate/list.tt');
 | |
| }
 | |
| 
 | |
| sub tmpl_list_restricted :Chained('tmpl_list') :PathPart('') :CaptureArgs(0) :Does(ACL) :ACLDetachTo('/denied_page') :AllowedRole(admin) :AllowedRole(reseller) {
 | |
|     my ($self, $c) = @_;
 | |
| }
 | |
| 
 | |
| sub tmpl_root :Chained('tmpl_list') :PathPart('') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
| }
 | |
| 
 | |
| sub tmpl_ajax :Chained('tmpl_list') :PathPart('ajax') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
| 
 | |
|     my $rs = $c->stash->{tmpl_rs};
 | |
|     NGCP::Panel::Utils::Datatables::process($c, $rs, $c->stash->{template_dt_columns});
 | |
|     $c->session->{email_template_external_filter} = 'all';
 | |
|     $c->detach( $c->view("JSON") );
 | |
| }
 | |
| 
 | |
| sub tmpl_ajax_reseller :Chained('tmpl_list') :PathPart('ajax') :Args(1) {
 | |
|     my ($self, $c, $reseller_id) = @_;
 | |
|     my $rs = $c->stash->{tmpl_rs}->search({
 | |
|         reseller_id => $reseller_id,
 | |
|     });
 | |
|     NGCP::Panel::Utils::Datatables::process($c, $rs, $c->stash->{template_dt_columns});
 | |
|     $c->detach( $c->view("JSON") );
 | |
| }
 | |
| 
 | |
| sub tmpl_ajax_default :Chained('tmpl_list') :PathPart('ajax/default') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
|     my $rs = $c->model('DB')->resultset('email_templates')->search({
 | |
|         'me.reseller_id' => undef,
 | |
|     });
 | |
|     my $dt_columns = NGCP::Panel::Utils::Datatables::set_columns($c, [
 | |
|             { name => 'id', search => 1, title => $c->loc('#') },
 | |
|             { name => 'name', search => 1, title => $c->loc('Name') },
 | |
|             { name => 'from_email', search => 1, title => $c->loc('From') },
 | |
|             { name => 'subject', search => 1, title => $c->loc('Subject') },
 | |
|         ]);
 | |
|     NGCP::Panel::Utils::Datatables::process($c, $rs, $dt_columns, sub {
 | |
|             my ($result) = @_;
 | |
|             my %data = (undeletable => ($c->user->roles eq "admin") ? 0 : 1);
 | |
|             return %data
 | |
|         },
 | |
|     );
 | |
|     $c->session->{email_template_external_filter} = 'default';
 | |
|     $c->detach( $c->view("JSON") );
 | |
| }
 | |
| 
 | |
| sub tmpl_ajax_missed :Chained('tmpl_list') :PathPart('ajax/missed') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
|     my $dt_columns = NGCP::Panel::Utils::Datatables::set_columns($c, [
 | |
|             { name => 'id', literal_sql => 'concat(me.id,"/",etd.id)', search => 1, title => $c->loc('#') },
 | |
|             { name => 'reseller_name', literal_sql => 'me.name', search => 1, title => $c->loc('Reseller') },
 | |
|             { name => 'email_template_name', literal_sql => 'etd.name', search => 1, title => $c->loc('Email template') },
 | |
|         ]);
 | |
|     NGCP::Panel::Utils::Datatables::process($c, $c->stash->{tmpl_missed_rs}, $dt_columns );
 | |
|     $c->detach( $c->view("JSON") );
 | |
| }
 | |
| 
 | |
| sub tmpl_create :Chained('tmpl_list_restricted') :PathPart('create') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
| 
 | |
|     my $posted = ($c->request->method eq 'POST');
 | |
|     my $form;
 | |
|     my $params = {};
 | |
|     $params = merge($params, $c->session->{created_objects});
 | |
|     if($c->user->roles eq "admin") {
 | |
|         $form = NGCP::Panel::Form::get("NGCP::Panel::Form::EmailTemplate::Admin", $c);
 | |
|     } elsif($c->user->roles eq "reseller") {
 | |
|         $form = NGCP::Panel::Form::get("NGCP::Panel::Form::EmailTemplate::Reseller", $c);
 | |
|     }
 | |
|     $form->process(
 | |
|         posted => $posted,
 | |
|         params => $c->request->params,
 | |
|         item   => $params,
 | |
|     );
 | |
|     NGCP::Panel::Utils::Navigation::check_form_buttons(
 | |
|         c => $c,
 | |
|         form => $form,
 | |
|         fields => {
 | |
|             'reseller.create' => $c->uri_for('/reseller/create'),
 | |
|         },
 | |
|         back_uri => $c->req->uri,
 | |
|     );
 | |
|     if($posted) {
 | |
|         $self->create_email_template($c, $form);
 | |
|     }
 | |
|     $c->stash(
 | |
|         form => $form,
 | |
|         create_flag => 1,
 | |
|     );
 | |
| }
 | |
| 
 | |
| sub tmpl_sync :Chained('tmpl_list_restricted') :PathPart('sync') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
| 
 | |
|     my $posted = ($c->request->method eq 'POST');
 | |
|     my $form = NGCP::Panel::Form::get("NGCP::Panel::Form::EmailTemplate::Sync", $c);
 | |
|     my $params = { id => encode_json([map { $_->id } $c->stash->{tmpl_missed_rs}->all]) };
 | |
| 
 | |
|     $form->process(
 | |
|         posted => $posted,
 | |
|         params => $c->request->params,
 | |
|         item   => $params,
 | |
|     );
 | |
|     if($posted) {
 | |
|         if($form->validated && $form->values->{id}) {
 | |
|             try {
 | |
|                 my $schema = $c->model('DB');
 | |
|                 my $pairs = decode_json($form->values->{id});
 | |
|                 foreach my $ids (@$pairs) {
 | |
|                     (my($reseller_id,$tmpl_id)) = $ids=~/(\d+)\D+(\d+)/;
 | |
|                     if($c->user->roles eq "reseller") {
 | |
|                         $form->values->{reseller_id} = $c->user->reseller_id;
 | |
|                     }
 | |
|                     my $template_rs = $schema->resultset('email_templates')->find($tmpl_id);
 | |
|                     my $template = { $template_rs->get_inflated_columns };
 | |
|                     delete $template->{id};
 | |
|                     $template->{reseller_id} = $reseller_id;
 | |
|                     $template->{attachment_name} //= '';
 | |
|                     $schema->txn_do(sub {
 | |
|                         my $tmpl = $c->stash->{tmpl_rs}->create($template);
 | |
|                     });
 | |
|                 }
 | |
|                 NGCP::Panel::Utils::Message::info(
 | |
|                     c    => $c,
 | |
|                     desc => $c->loc('Email template successfully synced'),
 | |
|                 );
 | |
|             } catch($e) {
 | |
|                 NGCP::Panel::Utils::Message::error(
 | |
|                     c     => $c,
 | |
|                     error => $e,
 | |
|                     desc  => $c->loc('Failed to sync email template'),
 | |
|                 );
 | |
|             }
 | |
|             NGCP::Panel::Utils::Navigation::back_or($c, $c->uri_for('/emailtemplate'));
 | |
|         }
 | |
|     }
 | |
|     $c->stash(
 | |
|         form => $form,
 | |
|         create_flag => 1,
 | |
|     );
 | |
| }
 | |
| 
 | |
| sub tmpl_base :Chained('tmpl_list_restricted') :PathPart('') :CaptureArgs(1) {
 | |
|     my ($self, $c, $tmpl_id) = @_;
 | |
| 
 | |
|     $c->detach('/denied_page')
 | |
|         if($c->user->read_only);
 | |
| 
 | |
|     unless ( $self->check_template_id($c, $tmpl_id) ) {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     my $rs = $c->stash->{tmpl_rs}->find($tmpl_id);
 | |
|     unless(defined($rs)) {
 | |
|         NGCP::Panel::Utils::Message::error(
 | |
|             c => $c,
 | |
|             log => 'Email template does not exist',
 | |
|             desc => $c->loc('Email template does not exist'),
 | |
|         );
 | |
|         $c->response->redirect($c->uri_for());
 | |
|         $c->detach;
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     $c->stash->{tmpl} = $rs;
 | |
| }
 | |
| 
 | |
| sub tmpl_delete :Chained('tmpl_base') :PathPart('delete') {
 | |
|     my ($self, $c) = @_;
 | |
| 
 | |
|     try {
 | |
|         foreach(qw/subscriber_email_template_id passreset_email_template_id invoice_email_template_id/){
 | |
|             $c->model('DB')->resultset('contracts')->search({
 | |
|                 $_ => $c->stash->{tmpl}->id,
 | |
|             })->update({
 | |
|                 $_ => undef,
 | |
|             });
 | |
|         }
 | |
|         $c->stash->{tmpl}->delete;
 | |
|         NGCP::Panel::Utils::Message::info(
 | |
|             c => $c,
 | |
|             data => { $c->stash->{tmpl}->get_inflated_columns },
 | |
|             desc => $c->loc('Email template successfully deleted'),
 | |
|         );
 | |
|     } catch ($e) {
 | |
|         NGCP::Panel::Utils::Message::error(
 | |
|             c => $c,
 | |
|             error => $e,
 | |
|             desc  => $c->loc('Failed to delete email template'),
 | |
|         );
 | |
|     };
 | |
|     $c->response->redirect($c->uri_for());
 | |
| }
 | |
| 
 | |
| sub tmpl_edit :Chained('tmpl_base') :PathPart('edit') {
 | |
|     my ($self, $c) = @_;
 | |
|     my ($posted, $form, $params) = $self->prepare_email_template_edit($c);
 | |
|     if($posted && $form->validated) {
 | |
|         try {
 | |
|             if($c->user->roles eq "admin") {
 | |
|                 $form->values->{reseller_id} = $form->values->{reseller}{id};
 | |
|             } elsif($c->user->roles eq "reseller") {
 | |
|                 # don't allow to change reseller id
 | |
|             }
 | |
|             delete $form->values->{reseller};
 | |
|             $form->values->{attachment_name} //= '';
 | |
| 
 | |
|             $c->model('DB')->txn_do(sub {
 | |
|                 $c->stash->{tmpl}->update($form->values);
 | |
| 
 | |
|             });
 | |
|             delete $c->session->{created_objects}->{reseller};
 | |
|             NGCP::Panel::Utils::Message::info(
 | |
|                 c    => $c,
 | |
|                 desc => $c->loc('Email template successfully updated'),
 | |
|             );
 | |
|         } catch($e) {
 | |
|             NGCP::Panel::Utils::Message::error(
 | |
|                 c     => $c,
 | |
|                 error => $e,
 | |
|                 desc  => $c->loc('Failed to update email template'),
 | |
|             );
 | |
|         };
 | |
|         NGCP::Panel::Utils::Navigation::back_or($c, $c->uri_for('/emailtemplate'));
 | |
|     }
 | |
| 
 | |
|     $c->stash(
 | |
|         form => $form,
 | |
|         edit_flag => 1,
 | |
|     );
 | |
| }
 | |
| 
 | |
| sub tmpl_copy :Chained('tmpl_list_restricted') :PathPart('copy'): Args(1) {
 | |
|     my ($self, $c, $tmpl_id) = @_;
 | |
| 
 | |
|     $c->detach('/denied_page')
 | |
|         if($c->user->read_only);
 | |
| 
 | |
|     unless ( $self->check_template_id($c, $tmpl_id) ) {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     my $tmpl = $c->model('DB')->resultset('email_templates')->find($tmpl_id);
 | |
|     $c->stash->{is_copy} = 1;
 | |
|     my ($posted, $form, $params) = $self->prepare_email_template_edit($c, $tmpl);
 | |
|     if($posted) {
 | |
|         $self->create_email_template($c, $form);
 | |
|     }
 | |
|     $c->stash(
 | |
|         form => $form,
 | |
|         create_flag => 1,
 | |
|     );
 | |
| }
 | |
| 
 | |
| sub check_template_id :Private {
 | |
|     my ($self, $c, $tmpl_id) = @_;
 | |
|     unless($tmpl_id && is_int($tmpl_id)) {
 | |
|         NGCP::Panel::Utils::Message::error(
 | |
|             c => $c,
 | |
|             log => 'Invalid email template id detected',
 | |
|             desc => $c->loc('Invalid email template id detected'),
 | |
|         );
 | |
|         $c->response->redirect($c->uri_for());
 | |
|         $c->detach;
 | |
|         return;
 | |
|     }
 | |
|     return 1;
 | |
| }
 | |
| 
 | |
| sub prepare_email_template_edit :Private {
 | |
|     my ($self, $c, $tmpl) = @_;
 | |
|     my $posted = ($c->request->method eq 'POST');
 | |
|     my $form;
 | |
|     $tmpl //= $c->stash->{tmpl};
 | |
|     my $params = { $tmpl->get_inflated_columns };
 | |
|     $params->{reseller}{id} = delete $params->{reseller_id};
 | |
|     $params = merge($params, $c->session->{created_objects});
 | |
|     if($c->user->roles eq "admin") {
 | |
|         $form = NGCP::Panel::Form::get("NGCP::Panel::Form::EmailTemplate::Admin", $c);
 | |
|     } elsif($c->user->roles eq "reseller") {
 | |
|         $form = NGCP::Panel::Form::get("NGCP::Panel::Form::EmailTemplate::Reseller", $c);
 | |
|     }
 | |
|     $form->process(
 | |
|         posted => $posted,
 | |
|         params => $c->request->params,
 | |
|         item   => $params,
 | |
|     );
 | |
|     NGCP::Panel::Utils::Navigation::check_form_buttons(
 | |
|         c => $c,
 | |
|         form => $form,
 | |
|         fields => {
 | |
|             'reseller.create' => $c->uri_for('/reseller/create'),
 | |
|         },
 | |
|         back_uri => $c->req->uri,
 | |
|     );
 | |
|     return $posted, $form, $params;
 | |
| }
 | |
| 
 | |
| sub create_email_template :Private {
 | |
|     my ($self, $c, $form) = @_;
 | |
|     if($form->validated) {
 | |
|         try {
 | |
|             if($c->user->roles eq "admin") {
 | |
|                 $form->values->{reseller_id} = $form->values->{reseller}{id};
 | |
|             } elsif($c->user->roles eq "reseller") {
 | |
|                 $form->values->{reseller_id} = $c->user->reseller_id;
 | |
|             }
 | |
|             delete $form->values->{reseller};
 | |
| 
 | |
|             $form->values->{attachment_name} //= '';
 | |
| 
 | |
|             my $schema = $c->model('DB');
 | |
|             $schema->txn_do(sub {
 | |
|                 my $tmpl = $c->stash->{tmpl_rs}->create($form->values);
 | |
|             });
 | |
| 
 | |
|             delete $c->session->{created_objects}->{reseller};
 | |
|             NGCP::Panel::Utils::Message::info(
 | |
|                 c    => $c,
 | |
|                 desc => $c->loc('Email template successfully created'),
 | |
|             );
 | |
|         } catch($e) {
 | |
|             NGCP::Panel::Utils::Message::error(
 | |
|                 c     => $c,
 | |
|                 error => $e,
 | |
|                 desc  => $c->loc('Failed to create email template'),
 | |
|             );
 | |
|         }
 | |
|         NGCP::Panel::Utils::Navigation::back_or($c, $c->uri_for('/emailtemplate'));
 | |
|     }
 | |
| }
 | |
| 
 | |
| sub send_test :Chained('tmpl_list') :PathPart('test') :Args(0) {
 | |
|     my ($self, $c) = @_;
 | |
| 
 | |
|     $c->stash(
 | |
|         template => 'emailtemplate/test.tt',
 | |
|         username => 'foobar',
 | |
|         url => 'http://foo.example.com',
 | |
|     );
 | |
| 
 | |
|     $c->forward($c->view('TT'));
 | |
|     my $body = $c->res->body;
 | |
|     $c->res->body(undef);
 | |
|     NGCP::Panel::Utils::Email::send_email(
 | |
|         from => 'noreply@yoursipserver.com',
 | |
|         to => 'agranig@sipwise.com',
 | |
|         subject => 'test from catalyst ' . time,
 | |
|         body => $body,
 | |
|     );
 | |
| 
 | |
|     $c->res->redirect($c->uri_for('/'));
 | |
| }
 | |
| 
 | |
| 1;
 | |
| # vim: set tabstop=4 expandtab:
 |