From 656c7d55b5f3bdd12b142d05707ceed4eaef17b5 Mon Sep 17 00:00:00 2001 From: ivan Date: Tue, 29 Sep 1998 18:55:21 +0000 Subject: [PATCH] Initial revision --- htdocs/view/svc_acct.cgi | 172 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 172 insertions(+) create mode 100755 htdocs/view/svc_acct.cgi diff --git a/htdocs/view/svc_acct.cgi b/htdocs/view/svc_acct.cgi new file mode 100755 index 000000000..7096c2fb1 --- /dev/null +++ b/htdocs/view/svc_acct.cgi @@ -0,0 +1,172 @@ +#!/usr/bin/perl -Tw +# +# View svc_acct records +# +# Usage: svc_acct.cgi svcnum +# http://server.name/path/svc_acct.cgi?svcnum +# +# Note: Should be run setuid freeside as user nobody. +# +# ivan@voicenet.com 96-dec-17 +# +# added link to send info +# ivan@voicenet.com 97-jan-4 +# +# added navigation bar and ability to change username, etc. +# ivan@voicenet.com 97-jan-30 +# +# activate 800 service +# ivan@voicenet.com 97-feb-10 +# +# modified navbar code (should be a subroutine?), added link to cancel account (only if not audited) +# ivan@voicenet.com 97-apr-16 +# +# INCOMPLETELY rewrote some things for new API +# ivan@voicenet.com 97-jul-29 +# +# FS::Search became FS::Record, use strict, etc. ivan@sisd.com 98-mar-9 +# +# Changes to allow page to work at a relative position in server +# Changed 'password' to '_password' because Pg6.3 reserves the password word +# bmccane@maxbaud.net 98-apr-3 +# +# /var/spool/freeside/conf/domain ivan@sisd.com 98-jul-17 +# +# displays arbitrary radius attributes ivan@sisd.com 98-aug-16 + +use strict; +use CGI::Base qw(:DEFAULT :CGI); +use CGI::Carp qw(fatalsToBrowser); +use FS::UID qw(cgisuidsetup); +use FS::Record qw(qsearchs fields); + +my($conf_domain)="/var/spool/freeside/conf/domain"; +open(DOMAIN,$conf_domain) or die "Can't open $conf_domain: $!"; +my($mydomain)=map { + /^(.*)$/ or die "Illegal line in $conf_domain!"; #yes, we trust the file + $1; +} grep $_ !~ /^(#|$)/, ; + +my($cgi) = new CGI::Base; +$cgi->get; +&cgisuidsetup($cgi); + +#untaint svcnum +$QUERY_STRING =~ /^(\d+)$/; +my($svcnum)=$1; +my($svc_acct)=qsearchs('svc_acct',{'svcnum'=>$svcnum}); +die "Unkonwn svcnum" unless $svc_acct; + +my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum}); +my($pkgnum)=$cust_svc->getfield('pkgnum'); +my($cust_pkg,$custnum); +if ($pkgnum) { + $cust_pkg=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum}); + $custnum=$cust_pkg->getfield('custnum'); +} + +my($part_svc)=qsearchs('part_svc',{'svcpart'=> $cust_svc->svcpart } ); +die "Unkonwn svcpart" unless $part_svc; + +SendHeaders(); # one guess. +print < + + Account View + + +

Account View

+ +
+END + +if ($pkgnum || $custnum) { + print <View this package (#$pkgnum) | +View this customer (#$custnum) | +END +} else { + print <Cancel this (unaudited)account | +END +} + +print <Main menu

+Service #$svcnum +END + +print qq!
Edit this information!; +#print qq!
Send account information!; +print qq!

General | Shell account | !; +print qq!SLIP/PPP account
!; + +#formatting +print qq!
General
!; + +#svc +print "Service: ", $part_svc->svc, ""; + +#username +print "
Username: ", $svc_acct->username, ""; + +#password +if (substr($svc_acct->_password,0,1) eq "*") { + print "
Password: (Login disabled)
"; +} else { + print "
Password: (hidden)
"; +} + +# popnum -> svc_acct_pop record +my($svc_acct_pop)=qsearchs('svc_acct_pop',{'popnum'=>$svc_acct->popnum}); + +#pop +print "POP: ", $svc_acct_pop->city, ", ", $svc_acct_pop->state, + " (", $svc_acct_pop->ac, ")/", $svc_acct_pop->exch, "<\B>" + if $svc_acct_pop; + +#shell account +print qq!
!; +if ($svc_acct->uid ne '') { + print "Shell account"; + print "
"; + print "Uid: ", $svc_acct->uid, ""; + print "
Gid: ", $svc_acct->gid, ""; + + print qq!
Finger name: !, $svc_acct->finger, qq!
!; + + print "Home directory: ", $svc_acct->dir, "
"; + + print "Shell: ", $svc_acct->shell, "
"; + + print "Quota: ", $svc_acct->quota, " (unimplemented)"; +} else { + print "No shell account."; +} + +# SLIP/PPP +print qq!
!; +if ($svc_acct->slipip) { + print "SLIP/PPP account
"; + 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) = ($1); + $pattribute =~ s/_/-/g; + print "
Radius $pattribute: ". $svc_acct->getfield($attribute), ""; + } +} else { + print "No SLIP/PPP account" +} + +print "
"; + + #formatting + print < + +END + -- 2.11.0