<% # use strict; use vars qw( $conf $cgi $domain $query $svcnum $svc_acct $cust_svc $pkgnum $cust_pkg $custnum $part_svc $p $svc_acct_pop $password $mydomain $svc_domain ); use CGI; use CGI::Carp qw( fatalsToBrowser ); use FS::UID qw( cgisuidsetup ); use FS::CGI qw( header popurl menubar ntable); use FS::Record qw( qsearchs fields ); use FS::Conf; use FS::svc_acct; use FS::cust_svc; use FS::cust_pkg; use FS::part_svc; use FS::svc_acct_pop; use FS::raddb; $cgi = new CGI; &cgisuidsetup($cgi); $conf = new FS::Conf; ($query) = $cgi->keywords; $query =~ /^(\d+)$/; $svcnum = $1; $svc_acct = qsearchs('svc_acct',{'svcnum'=>$svcnum}); die "Unknown svcnum" unless $svc_acct; $cust_svc = qsearchs('cust_svc',{'svcnum'=>$svcnum}); $pkgnum = $cust_svc->getfield('pkgnum'); if ($pkgnum) { $cust_pkg=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); $custnum=$cust_pkg->getfield('custnum'); } else { $cust_pkg = ''; $custnum = ''; } $part_svc = qsearchs('part_svc',{'svcpart'=> $cust_svc->svcpart } ); die "Unknown svcpart" unless $part_svc; if ( $svc_acct->domsvc ) { $svc_domain = qsearchs('svc_domain', { 'svcnum' => $svc_acct->domsvc } ); die "Unknown domain" unless $svc_domain; $domain = $svc_domain->domain; } else { unless ( $mydomain = $conf->config('domain') ) { die "No legacy domain config file and no svc_domain.svcnum record ". "for svc_acct.domsvc: ". $cust_svc->domsvc; } $domain = $mydomain; } $p = popurl(2); print $cgi->header( @FS::CGI::header ), header('Account View', menubar( ( ( $pkgnum || $custnum ) ? ( "View this package (#$pkgnum)" => "${p}view/cust_pkg.cgi?$pkgnum", "View this customer (#$custnum)" => "${p}view/cust_main.cgi?$custnum", ) : ( "Cancel this (unaudited) account" => "${p}misc/cancel-unaudited.cgi?$svcnum" ) ), "Main menu" => $p, )); #print qq!
Send account information!; print qq!Edit this information
!. &ntable("#cccccc"). ''. &ntable("#cccccc",2). "Service number". "$svcnum". "Service". "". $part_svc->svc. "". "Username". "". $svc_acct->username. "" ; print "Domain". "". $domain, ""; print "Password"; $password = $svc_acct->_password; if ( $password =~ /^\*\w+\* (.*)$/ ) { $password = $1; print "(login disabled) "; } if ( $conf->exists('showpasswords') ) { print "$password"; } else { print "(hidden)"; } print ""; $password = ''; $svc_acct_pop = qsearchs('svc_acct_pop',{'popnum'=>$svc_acct->popnum}); print "Access number". "". $svc_acct_pop->text. '' if $svc_acct_pop; if ($svc_acct->uid ne '') { print "Uid". "". $svc_acct->uid. "", "Gid". "". $svc_acct->gid. "", "GECOS". "". $svc_acct->finger. "", "Home directory". "". $svc_acct->dir. "", "Shell". "". $svc_acct->shell. "", "Quota". "". $svc_acct->quota. "" ; } else { print "(No shell account)"; } if ($svc_acct->slipip) { print "IP address". ( ( $svc_acct->slipip eq "0.0.0.0" || $svc_acct->slipip eq '0e0' ) ? "(Dynamic)" : $svc_acct->slipip ). ""; my($attribute); foreach $attribute ( grep /^radius_/, fields('svc_acct') ) { #warn $attribute; $attribute =~ /^radius_(.*)$/; my $pattribute = $FS::raddb::attrib{$1}; print "Radius (reply) $pattribute". "". $svc_acct->getfield($attribute). ""; } foreach $attribute ( grep /^rc_/, fields('svc_acct') ) { #warn $attribute; $attribute =~ /^rc_(.*)$/; my $pattribute = $FS::raddb::attrib{$1}; print "Radius (check) $pattribute: ". "". $svc_acct->getfield($attribute). ""; } } else { print "(No SLIP/PPP account)"; } print ""; %>