3 # $Id: svc_domain.cgi,v 1.10 2001-04-23 07:12:44 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.10 2001-04-23 07:12:44 ivan
19 # better error message (if kludgy) for no referral
20 # remove outdated NSI foo from domain ordering. also, fuck NSI.
22 # Revision 1.9 1999/02/28 00:03:39 ivan
23 # removed misleading comments
25 # Revision 1.8 1999/02/07 09:59:25 ivan
26 # more mod_perl fixes, and bugfixes Peter Wemm sent via email
28 # Revision 1.7 1999/01/19 05:13:46 ivan
29 # for mod_perl: no more top-level my() variables; use vars instead
30 # also the last s/create/new/;
32 # Revision 1.6 1999/01/18 09:41:35 ivan
33 # all $cgi->header calls now include ( '-expires' => 'now' ) for mod_perl
36 # Revision 1.5 1998/12/30 23:03:25 ivan
37 # bugfixes; fields isn't exported by derived classes
39 # Revision 1.4 1998/12/23 03:00:16 ivan
40 # $cgi->keywords instead of $cgi->query_string
42 # Revision 1.3 1998/12/17 06:17:12 ivan
43 # fix double // in relative URLs, s/CGI::Base/CGI/;
45 # Revision 1.2 1998/11/13 09:56:48 ivan
46 # change configuration file layout to support multiple distinct databases (with
47 # own set of config files, export, etc.)
51 use vars qw( $cgi $action $svcnum $svc_domain $pkgnum $svcpart $part_svc
52 $svc $otaker $domain $p1 $kludge_action $purpose );
54 use CGI::Carp qw(fatalsToBrowser);
55 use FS::UID qw(cgisuidsetup getotaker);
56 use FS::CGI qw(header popurl);
57 use FS::Record qw(qsearch qsearchs fields);
63 if ( $cgi->param('error') ) {
64 $svc_domain = new FS::svc_domain ( {
65 map { $_, scalar($cgi->param($_)) } fields('svc_domain')
67 $svcnum = $svc_domain->svcnum;
68 $pkgnum = $cgi->param('pkgnum');
69 $svcpart = $cgi->param('svcpart');
70 $kludge_action = $cgi->param('action');
71 $purpose = $cgi->param('purpose');
72 $part_svc = qsearchs('part_svc', { 'svcpart' => $svcpart } );
73 die "No part_svc entry!" unless $part_svc;
77 my($query) = $cgi->keywords;
78 if ( $query =~ /^(\d+)$/ ) { #editing
80 $svc_domain=qsearchs('svc_domain',{'svcnum'=>$svcnum})
81 or die "Unknown (svc_domain) svcnum!";
83 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
84 or die "Unknown (cust_svc) svcnum!";
86 $pkgnum=$cust_svc->pkgnum;
87 $svcpart=$cust_svc->svcpart;
89 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
90 die "No part_svc entry!" unless $part_svc;
94 $svc_domain = new FS::svc_domain({});
96 foreach $_ (split(/-/,$query)) {
97 $pkgnum=$1 if /^pkgnum(\d+)$/;
98 $svcpart=$1 if /^svcpart(\d+)$/;
100 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
101 die "No part_svc entry!" unless $part_svc;
105 #set fixed and default fields from part_svc
107 foreach $field ( fields('svc_domain') ) {
108 if ( $part_svc->getfield('svc_domain__'. $field. '_flag') ne '' ) {
109 $svc_domain->setfield($field,$part_svc->getfield('svc_domain__'. $field) );
115 $action = $svcnum ? 'Edit' : 'Add';
117 $svc = $part_svc->getfield('svc');
121 $domain = $svc_domain->domain;
124 print $cgi->header( '-expires' => 'now' ), header("$action $svc", '');
126 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
128 if $cgi->param('error');
131 <FORM ACTION="${p1}process/svc_domain.cgi" METHOD=POST>
132 <INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">
133 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">
134 <INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">
137 print qq!<INPUT TYPE="radio" NAME="action" VALUE="N"!;
138 print ' CHECKED' if $kludge_action eq 'N';
140 print qq!<BR><INPUT TYPE="radio" NAME="action" VALUE="M"!;
141 print ' CHECKED' if $kludge_action eq 'M';
145 <P>Domain <INPUT TYPE="text" NAME="domain" VALUE="$domain" SIZE=28 MAXLENGTH=26>
146 <BR>Purpose/Description: <INPUT TYPE="text" NAME="purpose" VALUE="$purpose" SIZE=64>
147 <P><CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>
149 <LI>COM is for commercial, for-profit organziations
150 <LI>ORG is for miscellaneous, usually, non-profit organizations
151 <LI>NET is for network infrastructure machines and organizations
152 <LI>EDU is for 4-year, degree granting institutions
153 <!-- <LI>GOV is for United States federal government agencies
156 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
157 and registration procedures.
158 <!-- <P>GOV registrations are limited to top-level US Federal Government agencies (see RFC 1816).