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:
|