<% # 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 ); use CGI; use CGI::Carp qw( fatalsToBrowser ); use FS::UID qw( cgisuidsetup ); use FS::CGI qw( header popurl menubar); 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( '-expires' => 'now' ), 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!, "
Service #$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)"; } $password = ''; $svc_acct_pop = qsearchs('svc_acct_pop',{'popnum'=>$svc_acct->popnum}); print "
POP: ", $svc_acct_pop->city, ", ", $svc_acct_pop->state, " (", $svc_acct_pop->ac, ")/", $svc_acct_pop->exch, "" if $svc_acct_pop; if ($svc_acct->uid ne '') { print "

Uid: ", $svc_acct->uid, "", "
Gid: ", $svc_acct->gid, "", "
Finger name: ", $svc_acct->finger, "", "
Home directory: ", $svc_acct->dir, "", "
Shell: ", $svc_acct->shell, "", "
Quota: ", $svc_acct->quota, " (unimplemented)" ; } 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 ""; %>