- Timestamp:
- 11/12/04 15:12:45 (20 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/cgi-bin/admin.cgi
r58 r65 3 3 # Hack interface to make specific changes to IPDB that (for one reason 4 4 # or another) can't be made through the main interface. 5 # 5 6 ### 6 7 # SVN revision info … … 9 10 # Last update by $Author$ 10 11 ### 12 # Copyright (C) 2004 - Kris Deugau 11 13 12 14 use strict; … … 85 87 Manually update allocation data in this /24: <input name=allocfrom> 86 88 <input type=submit value="Show allocations"> 89 </form> 90 <hr><a href="admin.cgi?action=showpools">List IP Pools</a> for manual tweaking and updates 87 91 ); 88 92 } else { … … 120 124 $webvar{custid}, $webvar{city}, $webvar{desc}, $webvar{notes}); 121 125 #my ($dbh,from,block,$type,$custid,$city,$desc,$notes) = @_; 122 } else { 123 print "webvar{action} check failed"; 126 } elsif ($webvar{action} eq 'showpools') { 127 print "IP Pools currently allocated:\n". 128 "<table border=1>\n<tr><td>Pool</td><td># of free IPs</td></tr>\n"; 129 $sth = $ip_dbh->prepare("select cidr from allocations where type like '%p' order by cidr"); 130 $sth->execute; 131 my %poolfree; 132 while (my @data = $sth->fetchrow_array) { 133 $poolfree{$data[0]} = 0; 134 } 135 $sth = $ip_dbh->prepare("select pool,ip from poolips where available='y' order by ip"); 136 $sth->execute; 137 while (my @data = $sth->fetchrow_array) { 138 $poolfree{$data[0]}++; 139 } 140 foreach my $key (keys %poolfree) { 141 print qq(<tr><td><a href="admin.cgi?action=tweakpool&pool=$key">$key</a></td>). 142 "<td>$poolfree{$key}</td></tr>\n"; 143 } 144 print "</table>\n"; 145 } elsif ($webvar{action} eq 'tweakpool') { 146 showPool($webvar{pool}); 147 } elsif ($webvar{action} eq 'updatepool') { 148 $sth = $ip_dbh->prepare("update poolips set custid='$webvar{custid}', ". 149 "city='$webvar{city}', ptype='$webvar{ptype}', available='". 150 (($webvar{available} eq 'y') ? 'y' : 'n'). 151 "', notes='$webvar{notes}', description='$webvar{desc}' ". 152 "where ip='$webvar{ip}'"); 153 $sth->execute; 154 if ($sth->err) { 155 print "Error updating pool IP $webvar{ip}: $@<hr>\n"; 156 syslog "err", "$authuser could not update pool IP $webvar{ip}: $@"; 157 } else { 158 $sth = $ip_dbh->prepare("select pool from poolips where ip='$webvar{ip}'"); 159 $sth->execute; 160 my @data = $sth->fetchrow_array; 161 print "$webvar{ip} in $data[0] updated\n<hr>\n"; 162 syslog "notice", "$authuser updated pool IP $webvar{ip}"; 163 } 164 showPool("$data[0]"); 165 #} else { 166 # print "webvar{action} check failed: $webvar{action}"; 124 167 } 125 168 … … 155 198 my $block = new NetAddr::IP $_[2]; 156 199 157 # First, figure out what free blocks will get mangled. 200 local $ip_dbh->{AutoCommit} = 0; # enable transactions, if possible 201 local $ip_dbh->{RaiseError} = 1; # Use local to limit to this sub 202 158 203 if ($from eq $block) { 159 # Whee! Easy. Just allocate the block 204 eval { 205 # common stuff for end-use, dialup, dynDSL, pools, etc, etc. 206 207 $sth = $ip_dbh->prepare("delete from freeblocks where cidr='$block'"); 208 $sth->execute; 209 210 # Insert the allocations entry 211 $sth = $ip_dbh->prepare("insert into allocations values ('$block',". 212 "'$custid','$type','$city','$desc','$notes',".$block->masklen.")"); 213 $sth->execute; 214 215 $ip_dbh->commit; 216 }; # end of eval 217 if ($@) { 218 carp "Transaction aborted because $@"; 219 eval { $ip_dbh->rollback; }; 220 syslog "err", "Allocation of '$webvar{fullcidr}' to '$webvar{custid}' as ". 221 "'$webvar{alloctype}' by $authuser failed: '$@'"; 222 printAndExit("Allocation of $cidr as $full_alloc_types{$webvar{alloctype}} failed.\n"); 223 } else { 224 syslog "notice", "$authuser allocated '$block' to '$custid'". 225 " as '$webvar{alloctype}'"; 226 print "Block $block allocated to $custid.<br>\n"; 227 } 160 228 } else { 161 229 # The complex case. An allocation from a larger block. … … 176 244 177 245 # insert the data here. Woo. 178 # Begin SQL transaction block 179 eval { 180 # Delete old freeblocks entry 181 $sth = $ip_dbh->prepare("delete from freeblocks where cidr='$from'"); 182 $sth->execute(); 183 184 # Insert the new freeblocks entries 185 $sth = $ip_dbh->prepare("insert into freeblocks values (?, ?, ". 186 "(select city from routed where cidr >>= '$block'),'y')"); 187 foreach my $block (@newfreeblocks) { 188 $sth->execute("$block", $block->masklen); 189 } 190 # Insert the allocations entry 191 $sth = $ip_dbh->prepare("insert into allocations values ('$block',". 192 "'$custid','$type','$city','$desc','$notes',".$block->masklen.")"); 193 $sth->execute; 194 195 $ip_dbh->commit; 196 }; # end eval 197 if ($@) { 198 carp "Transaction aborted because $@"; 199 eval { $ip_dbh->rollback; }; 200 syslog "err", "Allocation of '$block' to '$custid' as ". 201 "'$type' by $authuser failed: '$@'"; 202 print "Allocation of $block as $full_alloc_types{$type} failed.\n"; 203 } else { 204 syslog "notice", "$authuser allocated '$block' to '$custid'". 205 " as '$type'"; 206 print "OK!<br>\n"; 246 # Begin SQL transaction block 247 eval { 248 # Delete old freeblocks entry 249 $sth = $ip_dbh->prepare("delete from freeblocks where cidr='$from'"); 250 $sth->execute(); 251 252 # Insert the new freeblocks entries 253 $sth = $ip_dbh->prepare("insert into freeblocks values (?, ?, ". 254 "(select city from routed where cidr >>= '$block'),'y')"); 255 foreach my $block (@newfreeblocks) { 256 $sth->execute("$block", $block->masklen); 207 257 } 208 209 } 258 # Insert the allocations entry 259 $sth = $ip_dbh->prepare("insert into allocations values ('$block',". 260 "'$custid','$type','$city','$desc','$notes',".$block->masklen.")"); 261 $sth->execute; 262 263 $ip_dbh->commit; 264 }; # end eval 265 if ($@) { 266 carp "Transaction aborted because $@"; 267 eval { $ip_dbh->rollback; }; 268 syslog "err", "Allocation of '$block' to '$custid' as ". 269 "'$type' by $authuser failed: '$@'"; 270 print "Allocation of $block as $full_alloc_types{$type} failed.\n"; 271 } else { 272 syslog "notice", "$authuser allocated '$block' to '$custid'". 273 " as '$type'"; 274 print "Block $block allocated to $custid.<br>\n"; 275 } # done OK?/NOK! check after DB changes 276 277 } # done "hard" allocation case. 278 210 279 # need to get /24 that block is part of 211 280 my @bits = split /\./, $webvar{block}; … … 213 282 showAllocs((join ".", @bits)); 214 283 } 284 215 285 216 286 # List free blocks in a /24 for arbitrary manual allocation … … 298 368 carp "Transaction aborted because $@"; 299 369 eval { $ip_dbh->rollback; }; 300 syslog "err", "$authuser could not update block /IP'$webvar{block}': '$@'";370 syslog "err", "$authuser could not update block '$webvar{block}': '$@'"; 301 371 } else { 302 372 # If we get here, the operation succeeded. … … 309 379 showAllocs((join ".", @bits)); 310 380 } 381 382 383 # showPool() 384 # List all IPs in a pool, and allow arbitrary admin changes to each 385 # Allow changes to ALL fields 386 sub showPool($) { 387 my $pool = new NetAddr::IP $_[0]; 388 print qq(Listing pool $pool:\n<table border=1> 389 <form action=admin.cgi method=POST> 390 <input type=hidden name=action value=updatepool> 391 <tr><td align=right>Customer ID:</td><td><input name=custid></td></tr> 392 <tr><td align=right>Customer location:</td><td><input name=city></td></tr> 393 <tr><td align=right>Type:</td><td><select name=ptype><option selected>-</option> 394 <option value="s">Static IP - Server pool</option> 395 <option value="c">Static IP - Cable</option> 396 <option value="d">Static IP - DSL</option> 397 <option value="m">Static IP - Dialup</option> 398 <option value="w">Static IP - Wireless</option> 399 </select></td></tr> 400 <tr><td align=right>Available?</td><td><input type=checkbox value=y></td></tr> 401 <tr><td align=right>Description/name:</td><td><input name=desc size=40></td></tr> 402 <tr><td align=right>Notes:</td><td><textarea name=notes rows=3 cols=40></textarea></td></tr> 403 <tr><td colspan=2 align=center><input type=submit value="Update"></td></tr> 404 ). 405 "</table>Update the following record:<table border=1>\n"; 406 $sth = $ip_dbh->prepare("select * from poolips where pool='$pool' order by ip"); 407 $sth->execute; 408 while (my @data = $sth->fetchrow_array) { 409 print qq(<tr><td><input type=radio name=ip value="$data[1]">$data[1]</td>). 410 "<td>$data[2]</td><td>$data[3]</td><td>$data[4]</td>". 411 "<td>$data[5]</td><td>$data[6]</td><td>$data[7]</td></tr>\n"; 412 } 413 print "</form></table>\n"; 414 }
Note:
See TracChangeset
for help on using the changeset viewer.