4 my( $svcnum, $pkgnum, $svcpart, $part_svc, $svc_www );
5 if ( $cgi->param('error') ) {
6 $svc_www = new FS::svc_www ( {
7 map { $_, scalar($cgi->param($_)) } fields('svc_www')
9 $svcnum = $svc_www->svcnum;
10 $pkgnum = $cgi->param('pkgnum');
11 $svcpart = $cgi->param('svcpart');
12 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
13 die "No part_svc entry!" unless $part_svc;
15 my($query) = $cgi->keywords;
16 if ( $query =~ /^(\d+)$/ ) { #editing
18 $svc_www=qsearchs('svc_www',{'svcnum'=>$svcnum})
19 or die "Unknown (svc_www) svcnum!";
21 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
22 or die "Unknown (cust_svc) svcnum!";
24 $pkgnum=$cust_svc->pkgnum;
25 $svcpart=$cust_svc->svcpart;
27 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
28 die "No part_svc entry!" unless $part_svc;
32 $svc_www = new FS::svc_www({});
34 foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart
35 $pkgnum=$1 if /^pkgnum(\d+)$/;
36 $svcpart=$1 if /^svcpart(\d+)$/;
38 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
39 die "No part_svc entry!" unless $part_svc;
43 #set fixed and default fields from part_svc
44 foreach my $part_svc_column (
45 grep { $_->columnflag } $part_svc->all_part_svc_column
47 $svc_www->setfield( $part_svc_column->columnname,
48 $part_svc_column->columnvalue,
54 my $action = $svc_www->svcnum ? 'Edit' : 'Add';
56 my( %username, %arec );
59 my($u_part_svc,@u_acct_svcparts);
60 foreach $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
61 push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
64 my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
65 my($custnum)=$cust_pkg->getfield('custnum');
67 foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
68 my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
70 foreach $acct_svcpart (@u_acct_svcparts) { #now find the corresponding
71 #record(s) in cust_svc ( for this
74 foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) {
75 my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$i_cust_svc->getfield('svcnum')});
76 $username{$svc_acct->getfield('svcnum')}=$svc_acct->getfield('username');
82 my($d_part_svc,@d_acct_svcparts);
83 foreach $d_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_domain'}) ) {
84 push @d_acct_svcparts,$d_part_svc->getfield('svcpart');
87 foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
88 my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
90 foreach $acct_svcpart (@d_acct_svcparts) {
92 foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) {
93 my($svc_domain)=qsearchs('svc_domain',{'svcnum'=>$i_cust_svc->getfield('svcnum')});
95 foreach $domain_rec ( qsearch('domain_record',{
96 'svcnum' => $svc_domain->svcnum,
98 qsearch('domain_record',{
99 'svcnum' => $svc_domain->svcnum,
102 $arec{$domain_rec->recnum} =
103 $domain_rec->reczone eq '@'
104 ? $svc_domain->domain
105 : $domain_rec->reczone. '.'. $svc_domain->domain;
107 $arec{'@.'. $svc_domain->domain} = $svc_domain->domain
108 unless qsearchs('domain_record', { svcnum => $svc_domain->svcnum,
110 $arec{'www.'. $svc_domain->domain} = 'www.'. $svc_domain->domain
111 unless qsearchs('domain_record', { svcnum => $svc_domain->svcnum,
112 reczone => 'www', } );
117 } elsif ( $action eq 'Edit' ) {
119 my($domain_rec) = qsearchs('domain_record', { 'recnum'=>$svc_www->recnum });
120 $arec{$svc_www->recnum} = join '.', $domain_rec->recdata, $domain_rec->reczone;
123 die "\$action eq Add, but \$pkgnum is null!\n";
128 print header("Web Hosting $action", '');
130 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
132 if $cgi->param('error');
134 print qq!<FORM ACTION="${p1}process/svc_www.cgi" METHOD=POST>!;
141 print qq!<INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">!;
142 print qq!Service #<B>!, $svcnum ? $svcnum : "(NEW)", "</B><BR><BR>";
145 print qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!;
148 print qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!;
150 my($recnum,$usersvc)=(
155 print &ntable("#cccccc",2),
156 '<TR><TD ALIGN="right">Zone</TD><TD><SELECT NAME="recnum" SIZE=1>';
157 foreach $_ (keys %arec) {
158 print "<OPTION", $_ eq $recnum ? " SELECTED" : "",
159 qq! VALUE="$_">$arec{$_}!;
161 print "</SELECT></TD></TR>";
163 print '<TR><TD ALIGN="right">Username</TD><TD><SELECT NAME="usersvc" SIZE=1>';
164 foreach $_ (keys %username) {
165 print "<OPTION", ($_ eq $usersvc) ? " SELECTED" : "",
166 qq! VALUE="$_">$username{$_}!;
168 print "</SELECT></TD></TR>";
170 print '</TABLE><BR><INPUT TYPE="submit" VALUE="Submit">';