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