fix double // in relative URLs, s/CGI::Base/CGI/;
[freeside.git] / htdocs / edit / svc_acct.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: svc_acct.cgi,v 1.3 1998-12-17 06:17:08 ivan Exp $
4 #
5 # Usage: svc_acct.cgi {svcnum} | pkgnum{pkgnum}-svcpart{svcpart}
6 #        http://server.name/path/svc_acct.cgi? {svcnum} | pkgnum{pkgnum}-svcpart{svcpart}
7 #
8 # Note: Should be run setuid freeside as user nobody
9 #
10 # ivan@voicenet.com 96-dec-18
11 #
12 # rewrite ivan@sisd.com 98-mar-8
13 #
14 # Changes to allow page to work at a relative position in server
15 # Changed 'password' to '_password' because Pg6.3 reserves the password word
16 #       bmccane@maxbaud.net     98-apr-3
17 #
18 # use conf/shells and dbdef username length ivan@sisd.com 98-jul-13
19 #
20 # $Log: svc_acct.cgi,v $
21 # Revision 1.3  1998-12-17 06:17:08  ivan
22 # fix double // in relative URLs, s/CGI::Base/CGI/;
23 #
24
25 use strict;
26 use vars qw($conf);
27 use CGI;
28 use CGI::Carp qw(fatalsToBrowser);
29 use FS::UID qw(cgisuidsetup getotaker);
30 use FS::CGI qw(header popurl);
31 use FS::Record qw(qsearch qsearchs);
32 use FS::svc_acct qw(fields);
33 use FS::Conf;
34
35 my($cgi) = new CGI;
36 &cgisuidsetup($cgi);
37
38 $conf = new FS::Conf;
39 my @shells = $conf->config('shells');
40
41 my($action,$svcnum,$svc_acct,$pkgnum,$svcpart,$part_svc);
42
43 my($query) = $cgi->keywords;
44 if ( $query =~ /^(\d+)$/ ) { #editing
45
46   $svcnum=$1;
47   $svc_acct=qsearchs('svc_acct',{'svcnum'=>$svcnum})
48     or die "Unknown (svc_acct) svcnum!";
49
50   my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
51     or die "Unknown (cust_svc) svcnum!";
52
53   $pkgnum=$cust_svc->pkgnum;
54   $svcpart=$cust_svc->svcpart;
55
56   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
57   die "No part_svc entry!" unless $part_svc;
58
59   $action="Edit";
60
61 } else { #adding
62
63   $svc_acct=create FS::svc_acct({}); 
64
65   foreach $_ (split(/-/,$query)) {
66     $pkgnum=$1 if /^pkgnum(\d+)$/;
67     $svcpart=$1 if /^svcpart(\d+)$/;
68   }
69   $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
70   die "No part_svc entry!" unless $part_svc;
71
72   $svcnum='';
73
74   #set gecos
75   my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
76   if ($cust_pkg) {
77     my($cust_main)=qsearchs('cust_main',{'custnum'=> $cust_pkg->custnum } );
78     $svc_acct->setfield('finger',
79       $cust_main->getfield('first') . " " . $cust_main->getfield('last')
80     ) ;
81   }
82
83   #set fixed and default fields from part_svc
84   my($field);
85   foreach $field ( fields('svc_acct') ) {
86     if ( $part_svc->getfield('svc_acct__'. $field. '_flag') ne '' ) {
87       $svc_acct->setfield($field,$part_svc->getfield('svc_acct__'. $field) );
88     }
89   }
90
91   $action="Add";
92
93 }
94
95 my($svc)=$part_svc->getfield('svc');
96
97 my($otaker)=getotaker;
98
99 my($username,$password)=(
100   $svc_acct->username,
101   $svc_acct->_password ? "*HIDDEN*" : '',
102 );
103
104 my($ulen)=$svc_acct->dbdef_table->column('username')->length;
105 my($ulen2)=$ulen+2;
106
107 my $p1 = popurl(1);
108 print $cgi->header, header("$action $svc account"), <<END;
109     <FORM ACTION="${p1}process/svc_acct.cgi" METHOD=POST>
110       <INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">
111       <INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">
112       <INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">
113 Username: 
114 <INPUT TYPE="text" NAME="username" VALUE="$username" SIZE=$ulen2 MAXLENGTH=$ulen>
115 <BR>Password: 
116 <INPUT TYPE="text" NAME="_password" VALUE="$password" SIZE=10 MAXLENGTH=8> 
117 (blank to generate)
118 END
119
120 #pop
121 my($popnum)=$svc_acct->popnum || 0;
122 if ( $part_svc->svc_acct__popnum_flag eq "F" ) {
123   print qq!<INPUT TYPE="hidden" NAME="popnum" VALUE="$popnum">!;
124 } else { 
125   print qq!<BR>POP: <SELECT NAME="popnum" SIZE=1><OPTION>\n!;
126   my($svc_acct_pop);
127   foreach $svc_acct_pop ( qsearch ('svc_acct_pop',{} ) ) {
128   print "<OPTION", $svc_acct_pop->popnum == $popnum ? ' SELECTED' : '', ">", 
129         $svc_acct_pop->popnum, ": ", 
130         $svc_acct_pop->city, ", ",
131         $svc_acct_pop->state,
132         "(", $svc_acct_pop->ac, ")/",
133         $svc_acct_pop->exch, "\n"
134       ;
135   }
136   print "</SELECT>";
137 }
138
139 my($uid,$gid,$finger,$dir)=(
140   $svc_acct->uid,
141   $svc_acct->gid,
142   $svc_acct->finger,
143   $svc_acct->dir,
144 );
145
146 print <<END;
147 <INPUT TYPE="hidden" NAME="uid" VALUE="$uid">
148 <INPUT TYPE="hidden" NAME="gid" VALUE="$gid">
149 <BR>GECOS: <INPUT TYPE="text" NAME="finger" VALUE="$finger">
150 <INPUT TYPE="hidden" NAME="dir" VALUE="$dir">
151 END
152
153 my($shell)=$svc_acct->shell;
154 if ( $part_svc->svc_acct__shell_flag eq "F" ) {
155   print qq!<INPUT TYPE="hidden" NAME="shell" VALUE="$shell">!;
156 } else {
157   print qq!<BR>Shell: <SELECT NAME="shell" SIZE=1>!;
158   my($etc_shell);
159   foreach $etc_shell (@shells) {
160     print "<OPTION", $etc_shell eq $shell ? ' SELECTED' : '', ">",
161           $etc_shell, "\n";
162   }
163   print "</SELECT>";
164 }
165
166 my($quota,$slipip)=(
167   $svc_acct->quota,
168   $svc_acct->slipip,
169 );
170
171 print qq!<INPUT TYPE="hidden" NAME="quota" VALUE="$quota">!;
172
173 if ( $part_svc->svc_acct__slipip_flag eq "F" ) {
174   print qq!<INPUT TYPE="hidden" NAME="slipip" VALUE="$slipip">!;
175 } else {
176   print qq!<BR>IP: <INPUT TYPE="text" NAME="slipip" VALUE="$slipip">!;
177 }
178
179 #submit
180 print qq!<P><CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>!; 
181
182 print <<END;
183     </FORM>
184   </BODY>
185 </HTML>
186 END
187
188