3 # $Id: svc_domain.cgi,v 1.7 1999-01-19 05:13:46 ivan Exp $
5 # Usage: svc_domain.cgi pkgnum{pkgnum}-svcpart{svcpart}
6 # http://server.name/path/svc_domain.cgi?pkgnum{pkgnum}-svcpart{svcpart}
8 # Note: Should be run setuid freeside as user nobody
10 # ivan@voicenet.com 97-jan-5 -> 97-jan-6
12 # changes for domain template 3.5
13 # ivan@voicenet.com 97-jul-24
15 # rewrite ivan@sisd.com 98-mar-14
17 # no GOV in instructions ivan@sisd.com 98-jul-17
19 # $Log: svc_domain.cgi,v $
20 # Revision 1.7 1999-01-19 05:13:46 ivan
21 # for mod_perl: no more top-level my() variables; use vars instead
22 # also the last s/create/new/;
24 # Revision 1.6 1999/01/18 09:41:35 ivan
25 # all $cgi->header calls now include ( '-expires' => 'now' ) for mod_perl
28 # Revision 1.5 1998/12/30 23:03:25 ivan
29 # bugfixes; fields isn't exported by derived classes
31 # Revision 1.4 1998/12/23 03:00:16 ivan
32 # $cgi->keywords instead of $cgi->query_string
34 # Revision 1.3 1998/12/17 06:17:12 ivan
35 # fix double // in relative URLs, s/CGI::Base/CGI/;
37 # Revision 1.2 1998/11/13 09:56:48 ivan
38 # change configuration file layout to support multiple distinct databases (with
39 # own set of config files, export, etc.)
43 use vars qw( $cgi $action $svcnum $svc_domain $pkgnum $svcpart $part_svc
44 $query $svc $otaker $domain $p1 );
46 use CGI::Carp qw(fatalsToBrowser);
47 use FS::UID qw(cgisuidsetup getotaker);
48 use FS::CGI qw(header popurl);
49 use FS::Record qw(qsearch qsearchs fields);
55 ($query) = $cgi->keywords;
56 if ( $query =~ /^(\d+)$/ ) { #editing
59 $svc_domain=qsearchs('svc_domain',{'svcnum'=>$svcnum})
60 or die "Unknown (svc_domain) svcnum!";
62 my($cust_svc)=qsearchs('cust_svc',{'svcnum'=>$svcnum})
63 or die "Unknown (cust_svc) svcnum!";
65 $pkgnum=$cust_svc->pkgnum;
66 $svcpart=$cust_svc->svcpart;
68 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
69 die "No part_svc entry!" unless $part_svc;
75 $svc_domain = new FS::svc_domain({});
77 foreach $_ (split(/-/,$query)) {
78 $pkgnum=$1 if /^pkgnum(\d+)$/;
79 $svcpart=$1 if /^svcpart(\d+)$/;
81 $part_svc=qsearchs('part_svc',{'svcpart'=>$svcpart});
82 die "No part_svc entry!" unless $part_svc;
86 #set fixed and default fields from part_svc
88 foreach $field ( fields('svc_domain') ) {
89 if ( $part_svc->getfield('svc_domain__'. $field. '_flag') ne '' ) {
90 $svc_domain->setfield($field,$part_svc->getfield('svc_domain__'. $field) );
98 $svc = $part_svc->getfield('svc');
102 $domain = $svc_domain->domain;
105 print $cgi->header( '-expires' => 'now' ), header("$action $svc", ''), <<END;
106 <FORM ACTION="${p1}process/svc_domain.cgi" METHOD=POST>
107 <INPUT TYPE="hidden" NAME="svcnum" VALUE="$svcnum">
108 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">
109 <INPUT TYPE="hidden" NAME="svcpart" VALUE="$svcpart">
110 <INPUT TYPE="radio" NAME="action" VALUE="N">New
111 <BR><INPUT TYPE="radio" NAME="action" VALUE="M">Transfer
113 <P>Customer agrees to be bound by NSI's
114 <A HREF="http://rs.internic.net/help/agreement.txt">
115 Domain Name Registration Agreement</A>
116 <SELECT NAME="legal" SIZE=1><OPTION SELECTED>No<OPTION>Yes</SELECT>
117 <P>Domain <INPUT TYPE="text" NAME="domain" VALUE="$domain" SIZE=28 MAXLENGTH=26>
118 <BR>Purpose/Description: <INPUT TYPE="text" NAME="purpose" VALUE="" SIZE=64>
119 <P><CENTER><INPUT TYPE="submit" VALUE="Submit"></CENTER>
121 <LI>COM is for commercial, for-profit organziations
122 <LI>ORG is for miscellaneous, usually, non-profit organizations
123 <LI>NET is for network infrastructure machines and organizations
124 <LI>EDU is for 4-year, degree granting institutions
125 <!-- <LI>GOV is for United States federal government agencies
128 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
129 and registration procedures.
130 <!-- <P>GOV registrations are limited to top-level US Federal Government agencies (see RFC 1816).