From 3a60a97c305ee65b6a3c61c4b7f4bc35f8163356 Mon Sep 17 00:00:00 2001 From: ivan Date: Sun, 26 Jul 1998 21:25:09 +0000 Subject: Initial revision --- htdocs/view/svc_acct_sm.cgi | 114 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 114 insertions(+) create mode 100755 htdocs/view/svc_acct_sm.cgi (limited to 'htdocs/view') diff --git a/htdocs/view/svc_acct_sm.cgi b/htdocs/view/svc_acct_sm.cgi new file mode 100755 index 000000000..42623eefd --- /dev/null +++ b/htdocs/view/svc_acct_sm.cgi @@ -0,0 +1,114 @@ +#!/usr/bin/perl -Tw +# +# View svc_acct_sm records +# +# Usage: svc_acct_sm.cgi svcnum +# http://server.name/path/svc_acct_sm.cgi?svcnum +# +# Note: Should be run setuid freeside as user nobody. +# +# based on view/svc_acct.cgi +# +# ivan@voicenet.com 97-jan-5 +# +# added navigation bar +# ivan@voicenet.com 97-jan-30 +# +# rewrite ivan@sisd.com 98-mar-15 +# +# Changes to allow page to work at a relative position in server +# bmccane@maxbaud.net 98-apr-3 +# +# /var/spool/freeside/conf/domain ivan@sisd.com 98-jul-17 + +use strict; +use CGI::Base qw(:DEFAULT :CGI); +use FS::UID qw(cgisuidsetup); +use FS::Record qw(qsearchs); + +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 $_ !~ /^(#|$)/, ; +close DOMAIN; + +my($cgi) = new CGI::Base; +$cgi->get; +cgisuidsetup($cgi); + +#untaint svcnum +$QUERY_STRING =~ /^(\d+)$/; +my($svcnum)=$1; +my($svc_acct_sm)=qsearchs('svc_acct_sm',{'svcnum'=>$svcnum}); +die "Unknown svcnum" unless $svc_acct_sm; + +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 < + + Mail Alias View + + +

Mail Alias 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 +

Edit this information + +END + +my($domsvc,$domuid,$domuser)=( + $svc_acct_sm->domsvc, + $svc_acct_sm->domuid, + $svc_acct_sm->domuser, +); +my($svc) = $part_svc->svc; +my($svc_domain)=qsearchs('svc_domain',{'svcnum'=>$domsvc}); +my($domain)=$svc_domain->domain; +my($svc_acct)=qsearchs('svc_acct',{'uid'=>$domuid}); +my($username)=$svc_acct->username; + +#formatting +print qq!


!; + +#svc +print "Service: $svc"; + +print "
"; + +print qq!Mail to !, ( ($domuser eq '*') ? "(anything)" : $domuser ) , qq!\@$domain forwards to $username\@$mydomain mailbox.!; + +print "
"; + + #formatting + print < + +END + -- cgit v1.2.1