1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
% if ( $custnum ) {
<% include("/elements/header.html","View mail forward") %>
<% include( '/elements/small_custview.html', $custnum, '', 1,
"${p}view/cust_main.cgi") %>
<BR>
% } else {
<% include("/elements/header.html",'View mail forward', menubar(
"Cancel this (unaudited) mail forward" =>
"javascript:areyousure('${p}misc/cancel-unaudited.cgi?$svcnum')",
))
%>
<SCRIPT>
function areyousure(href) {
if (confirm("Permanently delete this mail forward?") == true)
window.location.href = href;
}
</SCRIPT>
% }
<A HREF="<% $p %>edit/svc_forward.cgi?<% $svcnum %>">Edit this information</A>
<% ntable("#cccccc",2) %>
<TR>
<TD ALIGN="right">Service number</TD>
<TD BGCOLOR="#ffffff"><% $svcnum %></TD>
</TR>
<TR>
<TD ALIGN="right">Service</TD>
<TD BGCOLOR="#ffffff"><% $svc %></TD>
</TR>
<TR>
<TD ALIGN="right">Email to</TD>
<TD BGCOLOR="#ffffff"><% $source %></TD>
</TR>
<TR>
<TD ALIGN="right">Forwards to </TD>
<TD BGCOLOR="#ffffff"><% $destination %></TD>
</TR>
% foreach (sort { $a cmp $b } $svc_forward->virtual_fields) {
<% $svc_forward->pvf($_)->widget('HTML', 'view', $svc_forward->getfield($_)) %>
% }
</TABLE>
<BR>
<% include('elements/svc_export_settings.html', $svc_forward) %>
<% joblisting({'svcnum'=>$svcnum}, 1) %>
<% include('/elements/footer.html') %>
<%init>
die "access denied"
unless $FS::CurrentUser::CurrentUser->access_right('View customer services');
my $conf = new FS::Conf;
my($query) = $cgi->keywords;
$query =~ /^(\d+)$/;
my $svcnum = $1;
my $svc_forward = qsearchs({
'select' => 'svc_forward.*',
'table' => 'svc_forward',
'addl_from' => ' LEFT JOIN cust_svc USING ( svcnum ) '.
' LEFT JOIN cust_pkg USING ( pkgnum ) '.
' LEFT JOIN cust_main USING ( custnum ) ',
'hashref' => {'svcnum'=>$svcnum},
'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql(
'null_right' => 'View/link unlinked services'
),
});
die "Unknown svcnum" unless $svc_forward;
my $cust_svc = qsearchs('cust_svc',{'svcnum'=>$svcnum});
my $pkgnum = $cust_svc->getfield('pkgnum');
my($cust_pkg, $custnum, $display_custnum);
if ($pkgnum) {
$cust_pkg=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
$custnum=$cust_pkg->getfield('custnum');
$display_custnum = $cust_pkg->cust_main->display_custnum;
} else {
$cust_pkg = '';
$custnum = '';
}
my $part_svc = qsearchs('part_svc',{'svcpart'=> $cust_svc->svcpart } )
or die "Unknown svcpart";
my($srcsvc,$dstsvc,$dst) = (
$svc_forward->srcsvc,
$svc_forward->dstsvc,
$svc_forward->dst,
);
my $src = $svc_forward->dbdef_table->column('src') ? $svc_forward->src : '';
my $svc = $part_svc->svc;
my $source;
if ($srcsvc) {
my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$srcsvc})
or die "Corrupted database: no svc_acct.svcnum matching srcsvc $srcsvc";
$source = $svc_acct->email;
} else {
$source = $src;
}
my $destination;
if ($dstsvc) {
my $svc_acct = qsearchs('svc_acct',{'svcnum'=>$dstsvc})
or die "Corrupted database: no svc_acct.svcnum matching dstsvc $dstsvc";
$destination = $svc_acct->email;
} else {
$destination = $dst;
}
</%init>
|