3 # $Id: svc_domain.cgi,v 1.1 2001-07-30 07:36:04 ivan Exp $
5 # Usage: svc_domain.cgi pkgnum{pkgnum}-svcpart{svcpart}
6 # http://server.name/path/svc_domain.cgi?pkgnum{pkgnum}-svcpart{svcpart}
8 # ivan@voicenet.com 97-jan-5 -> 97-jan-6
10 # changes for domain template 3.5
11 # ivan@voicenet.com 97-jul-24
13 # rewrite ivan@sisd.com 98-mar-14
15 # no GOV in instructions ivan@sisd.com 98-jul-17
17 # $Log: svc_domain.cgi,v $
18 # Revision 1.1 2001-07-30 07:36:04 ivan
21 # Revision 1.10 2001/04/23 07:12:44 ivan
22 # better error message (if kludgy) for no referral
23 # remove outdated NSI foo from domain ordering. also, fuck NSI.
25 # Revision 1.9 1999/02/28 00:03:39 ivan
26 # removed misleading comments
28 # Revision 1.8 1999/02/07 09:59:25 ivan
29 # more mod_perl fixes, and bugfixes Peter Wemm sent via email
31 # Revision 1.7 1999/01/19 05:13:46 ivan
32 # for mod_perl: no more top-level my() variables; use vars instead
33 # also the last s/create/new/;
35 # Revision 1.6 1999/01/18 09:41:35 ivan
36 # all $cgi->header calls now include ( '-expires' => 'now' ) for mod_perl
39 # Revision 1.5 1998/12/30 23:03:25 ivan
40 # bugfixes; fields isn't exported by derived classes
42 # Revision 1.4 1998/12/23 03:00:16 ivan
43 # $cgi->keywords instead of $cgi->query_string
45 # Revision 1.3 1998/12/17 06:17:12 ivan
46 # fix double // in relative URLs, s/CGI::Base/CGI/;
48 # Revision 1.2 1998/11/13 09:56:48 ivan
49 # change configuration file layout to support multiple distinct databases (with
50 # own set of config files, export, etc.)
54 use vars qw( $cgi $action $svcnum $svc_domain $pkgnum $svcpart $part_svc
55 $svc $otaker $domain $p1 $kludge_action $purpose );
57 use CGI::Carp qw(fatalsToBrowser);
58 use FS::UID qw(cgisuidsetup getotaker);
59 use FS::CGI qw(header popurl);
60 use FS::Record qw(qsearch qsearchs fields);
66 if ( $cgi->param('error') ) {
67 $svc_domain = new FS::svc_domain ( {
68 map { $_, scalar($cgi->param($_)) } fields('svc_domain')
70 $svcnum = $svc_domain->svcnum;
71 $pkgnum = $cgi->param('pkgnum');
72 $svcpart = $cgi->param('svcpart');
73 $kludge_action = $cgi->param('action');
74 $purpose = $cgi->param('purpose');
75 $part_svc = qsearchs('part_svc', { 'svcpart' => $svcpart } );
76 die "No part_svc entry!" unless $part_svc;
80 my($query) = $cgi->keywords;
81 if ( $query =~ /^(\d+)$/ ) { #editing
83 $svc_domain=qsearchs('svc_domain',{'svcnum'=>$svcnum})
84 or die "Unknown (svc_domain) svcnum!";
86 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
87 or die "Unknown (cust_svc) svcnum!";
89 $pkgnum=$cust_svc->pkgnum;
90 $svcpart=$cust_svc->svcpart;
92 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
93 die "No part_svc entry!" unless $part_svc;
97 $svc_domain = new FS::svc_domain({});
99 foreach $_ (split(/-/,$query)) {
100 $pkgnum=$1 if /^pkgnum(\d+)$/;
101 $svcpart=$1 if /^svcpart(\d+)$/;
103 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
104 die "No part_svc entry!" unless $part_svc;
108 #set fixed and default fields from part_svc
110 foreach $field ( fields('svc_domain') ) {
111 if ( $part_svc->getfield('svc_domain__'. $field. '_flag') ne '' ) {
112 $svc_domain->setfield($field,$part_svc->getfield('svc_domain__'. $field) );
118 $action = $svcnum ? 'Edit' : 'Add';
120 $svc = $part_svc->getfield('svc');
124 $domain = $svc_domain->domain;
127 print $cgi->header( '-expires' => 'now' ), header("$action $svc", '');
129 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
131 if $cgi->param('error');
134 <FORM ACTION="${p1}process/svc_domain.cgi" METHOD=POST>
135 <INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">
136 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">
137 <INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">
140 print qq!<INPUT TYPE="radio" NAME="action" VALUE="N"!;
141 print ' CHECKED' if $kludge_action eq 'N';
143 print qq!<BR><INPUT TYPE="radio" NAME="action" VALUE="M"!;
144 print ' CHECKED' if $kludge_action eq 'M';
148 <P>Domain <INPUT TYPE="text" NAME="domain" VALUE="$domain" SIZE=28 MAXLENGTH=26>
149 <BR>Purpose/Description: <INPUT TYPE="text" NAME="purpose" VALUE="$purpose" SIZE=64>
150 <P><CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>
152 <LI>COM is for commercial, for-profit organziations
153 <LI>ORG is for miscellaneous, usually, non-profit organizations
154 <LI>NET is for network infrastructure machines and organizations
155 <LI>EDU is for 4-year, degree granting institutions
156 <!-- <LI>GOV is for United States federal government agencies
159 US state and local government agencies, schools, libraries, museums, and individuals should register under the US domain. See RFC 1480 for a complete description of the US domain
160 and registration procedures.
161 <!-- <P>GOV registrations are limited to top-level US Federal Government agencies (see RFC 1816).