This commit was generated by cvs2svn to compensate for changes in r3874,
[freeside.git] / httemplate / edit / process / part_pkg.cgi
1 <%
2
3 my $dbh = dbh;
4
5 my $pkgpart = $cgi->param('pkgpart');
6
7 my $old = qsearchs('part_pkg',{'pkgpart'=>$pkgpart}) if $pkgpart;
8
9 #fixup plandata
10 my $plandata = $cgi->param('plandata');
11 my @plandata = split(',', $plandata);
12 $cgi->param('plandata', 
13   join('', map { "$_=". join(', ', $cgi->param($_)). "\n" } @plandata )
14 );
15
16 foreach (qw( setuptax recurtax disabled )) {
17   $cgi->param($_, '') unless defined $cgi->param($_);
18 }
19
20 my $new = new FS::part_pkg ( {
21   map {
22     $_, scalar($cgi->param($_));
23   } fields('part_pkg')
24 } );
25
26 #warn "setuptax: ". $new->setuptax;
27 #warn "recurtax: ". $new->recurtax;
28
29 #most of the stuff below should move to part_pkg.pm
30
31 foreach my $part_svc ( qsearch('part_svc', {} ) ) {
32   my $quantity = $cgi->param('pkg_svc'. $part_svc->svcpart) || 0;
33   unless ( $quantity =~ /^(\d+)$/ ) {
34     $cgi->param('error', "Illegal quantity" );
35     print $cgi->redirect(popurl(2). "part_pkg.cgi?". $cgi->query_string );
36     myexit();
37   }
38 }
39
40 local $SIG{HUP} = 'IGNORE';
41 local $SIG{INT} = 'IGNORE';
42 local $SIG{QUIT} = 'IGNORE';
43 local $SIG{TERM} = 'IGNORE';
44 local $SIG{TSTP} = 'IGNORE';
45 local $SIG{PIPE} = 'IGNORE';
46
47 local $FS::UID::AutoCommit = 0;
48
49 my $error;
50 if ( $pkgpart ) {
51   $error = $new->replace($old);
52 } else {
53   $error = $new->insert;
54   $pkgpart=$new->pkgpart;
55 }
56 if ( $error ) {
57   $dbh->rollback;
58   $cgi->param('error', $error );
59   print $cgi->redirect(popurl(2). "part_pkg.cgi?". $cgi->query_string );
60   myexit();
61 }
62
63 foreach my $part_svc (qsearch('part_svc',{})) {
64   my $quantity = $cgi->param('pkg_svc'. $part_svc->svcpart) || 0;
65   my $primary_svc =
66     $cgi->param('pkg_svc_primary') == $part_svc->svcpart ? 'Y' : '';
67   my $old_pkg_svc = qsearchs('pkg_svc', {
68     'pkgpart' => $pkgpart,
69     'svcpart' => $part_svc->svcpart,
70   } );
71   my $old_quantity = $old_pkg_svc ? $old_pkg_svc->quantity : 0;
72   my $old_primary_svc =
73     ( $old_pkg_svc && $old_pkg_svc->dbdef_table->column('primary_svc') )
74       ? $old_pkg_svc->primary_svc
75       : '';
76   next unless $old_quantity != $quantity || $old_primary_svc ne $primary_svc;
77
78   my $new_pkg_svc = new FS::pkg_svc( {
79     'pkgpart'     => $pkgpart,
80     'svcpart'     => $part_svc->svcpart,
81     'quantity'    => $quantity, 
82     'primary_svc' => $primary_svc,
83   } );
84   if ( $old_pkg_svc ) {
85     my $myerror = $new_pkg_svc->replace($old_pkg_svc);
86     if ( $myerror ) {
87       $dbh->rollback;
88       die $myerror;
89     }
90   } else {
91     my $myerror = $new_pkg_svc->insert;
92     if ( $myerror ) {
93       $dbh->rollback;
94       die $myerror;
95     }
96   }
97 }
98
99 unless ( $cgi->param('pkgnum') && $cgi->param('pkgnum') =~ /^(\d+)$/ ) {
100   $dbh->commit or die $dbh->errstr;
101   print $cgi->redirect(popurl(3). "browse/part_pkg.cgi");
102 } else {
103   my($old_cust_pkg) = qsearchs( 'cust_pkg', { 'pkgnum' => $1 } );
104   my %hash = $old_cust_pkg->hash;
105   $hash{'pkgpart'} = $pkgpart;
106   my($new_cust_pkg) = new FS::cust_pkg \%hash;
107   my $myerror = $new_cust_pkg->replace($old_cust_pkg);
108   if ( $myerror ) {
109     $dbh->rollback;
110     die "Error modifying cust_pkg record: $myerror\n";
111   }
112
113   $dbh->commit or die $dbh->errstr;
114   print $cgi->redirect(popurl(3). "view/cust_main.cgi?". $new_cust_pkg->custnum);
115 }
116
117 %>