21bd6a9ee37dbbf0c271c4712abed37b4bcf5e81
[freeside.git] / httemplate / edit / svc_acct_sm.cgi
1 <%
2 #<!-- $Id: svc_acct_sm.cgi,v 1.4 2001-09-11 23:44:01 ivan Exp $ -->
3
4 use strict;
5 use vars qw( $conf $cgi $mydomain $action $svcnum $svc_acct_sm $pkgnum $svcpart
6              $part_svc $query %username %domain $p1 $domuser $domsvc $domuid );
7 use CGI;
8 use CGI::Carp qw(fatalsToBrowser);
9 use FS::UID qw(cgisuidsetup);
10 use FS::CGI qw(header popurl);
11 use FS::Record qw(qsearch qsearchs fields);
12 use FS::svc_acct_sm;
13 use FS::Conf;
14
15 $cgi = new CGI;
16 &cgisuidsetup($cgi);
17
18 $conf = new FS::Conf;
19 $mydomain = $conf->config('domain');
20
21 if ( $cgi->param('error') ) {
22   $svc_acct_sm = new FS::svc_acct_sm ( {
23     map { $_, scalar($cgi->param($_)) } fields('svc_acct_sm')
24   } );
25   $svcnum = $svc_acct_sm->svcnum;
26   $pkgnum = $cgi->param('pkgnum');
27   $svcpart = $cgi->param('svcpart');
28   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
29   die "No part_svc entry!" unless $part_svc;
30 } else {
31   my($query) = $cgi->keywords;
32   if ( $query =~ /^(\d+)$/ ) { #editing
33     $svcnum=$1;
34     $svc_acct_sm=qsearchs('svc_acct_sm',{'svcnum'=>$svcnum})
35       or die "Unknown (svc_acct_sm) svcnum!";
36
37     my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
38       or die "Unknown (cust_svc) svcnum!";
39
40     $pkgnum=$cust_svc->pkgnum;
41     $svcpart=$cust_svc->svcpart;
42   
43     $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
44     die "No part_svc entry!" unless $part_svc;
45
46   } else { #adding
47
48     $svc_acct_sm = new FS::svc_acct_sm({});
49
50     foreach $_ (split(/-/,$query)) { #get & untaint pkgnum & svcpart
51       $pkgnum=$1 if /^pkgnum(\d+)$/;
52       $svcpart=$1 if /^svcpart(\d+)$/;
53     }
54     $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
55     die "No part_svc entry!" unless $part_svc;
56
57     $svcnum='';
58
59     #set fixed and default fields from part_svc
60     foreach my $part_svc_column (
61       grep { $_->columnflag } $part_svc->all_part_svc_column
62     ) {
63       $svc_acct_sm->setfield( $part_svc_column->columnname,
64                               $part_svc_column->columnvalue,
65                             );
66     }
67
68   }
69 }
70 $action = $svc_acct_sm->svcnum ? 'Edit' : 'Add';
71
72 if ($pkgnum) {
73
74   #find all possible uids (and usernames)
75
76   my @u_acct_svcparts = ();
77   foreach my $u_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_acct'}) ) {
78     push @u_acct_svcparts,$u_part_svc->getfield('svcpart');
79   }
80
81   my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
82   my($custnum)=$cust_pkg->getfield('custnum');
83   %username = ();
84   foreach my $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
85     my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
86     my($acct_svcpart);
87     foreach $acct_svcpart (@u_acct_svcparts) {   #now find the corresponding 
88                                               #record(s) in cust_svc ( for this
89                                               #pkgnum ! )
90       my($i_cust_svc);
91       foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) {
92         my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$i_cust_svc->getfield('svcnum')});
93         $username{$svc_acct->getfield('uid')}=$svc_acct->getfield('username');
94       }  
95     }
96   }
97
98   #find all possible domains (and domsvc's)
99
100   my @d_acct_svcparts = ();
101   foreach my $d_part_svc ( qsearch('part_svc',{'svcdb'=>'svc_domain'}) ) {
102     push @d_acct_svcparts,$d_part_svc->getfield('svcpart');
103   }
104
105   %domain = ();
106   foreach $i_cust_pkg ( qsearch('cust_pkg',{'custnum'=>$custnum}) ) {
107     my($cust_pkgnum)=$i_cust_pkg->getfield('pkgnum');
108     my($acct_svcpart);
109     foreach $acct_svcpart (@d_acct_svcparts) {
110       my($i_cust_svc);
111       foreach $i_cust_svc ( qsearch('cust_svc',{'pkgnum'=>$cust_pkgnum,'svcpart'=>$acct_svcpart}) ) {
112         my($svc_domain)=qsearch('svc_domain',{'svcnum'=>$i_cust_svc->getfield('svcnum')});
113         $domain{$svc_domain->getfield('svcnum')}=$svc_domain->getfield('domain');
114       }
115     }
116   }
117
118 } elsif ( $action eq 'Edit' ) {
119
120   my($svc_acct)=qsearchs('svc_acct',{'uid'=>$svc_acct_sm->domuid});
121   $username{$svc_acct_sm->uid} = $svc_acct->username;
122
123   my($svc_domain)=qsearchs('svc_domain',{'svcnum'=>$svc_acct_sm->domsvc});
124   $domain{$svc_acct_sm->domsvc} = $svc_domain->domain;
125
126 } else {
127   die "\$action eq Add, but \$pkgnum is null!\n";
128 }
129
130 $p1 = popurl(1);
131 print $cgi->header( '-expires' => 'now' ), header("Mail Alias $action", '');
132
133 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
134       "</FONT>"
135   if $cgi->param('error');
136
137 print qq!<FORM ACTION="${p1}process/svc_acct_sm.cgi" METHOD=POST>!;
138
139 #display
140
141         #formatting
142         print "<PRE>";
143
144 #svcnum
145 print qq!<INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">!;
146 print qq!Service #<FONT SIZE=+1><B>!, $svcnum ? $svcnum : " (NEW)", "</B></FONT>";
147
148 #pkgnum
149 print qq!<INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">!;
150  
151 #svcpart
152 print qq!<INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">!;
153
154 ($domuser,$domsvc,$domuid)=(
155   $svc_acct_sm->domuser,
156   $svc_acct_sm->domsvc,
157   $svc_acct_sm->domuid,
158 );
159
160 #domuser
161 print qq!\n\nMail to <INPUT TYPE="text" NAME="domuser" VALUE="$domuser"> <I>( * for anything )</I>!;
162
163 #domsvc
164 print qq! \@ <SELECT NAME="domsvc" SIZE=1>!;
165 foreach $_ (keys %domain) {
166   print "<OPTION", $_ eq $domsvc ? " SELECTED" : "",
167         qq! VALUE="$_">$domain{$_}!;
168 }
169 print "</SELECT>";
170
171 #uid
172 print qq!\nforwards to <SELECT NAME="domuid" SIZE=1>!;
173 foreach $_ (keys %username) {
174   print "<OPTION", ($_ eq $domuid) ? " SELECTED" : "",
175         qq! VALUE="$_">$username{$_}!;
176 }
177 print "</SELECT>\@$mydomain mailbox.";
178
179         #formatting
180         print "</PRE>\n";
181
182 print qq!<CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>!;
183
184 print <<END;
185
186     </FORM>
187   </BODY>
188 </HTML>
189 END
190
191 %>