blob: ecb7229430a8f81172e45bb9703c0b1976b559cc (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
#!/usr/bin/perl -w
#This drops anything from the database that could cause live things to happen.
#You'd want to do this on a test copy of your live database but NEVER on the
#live database itself.
die "remove this line to run -- NEVER ON A LIVE DATABASE";
#-all exports (all records in part_export, part_export_option export_svc)
#-all non-POST invoice destinations (cust_main_invoice)
#-all payment gateways and agent payment gw overrides (payment_gateway,
# payment_gateway_option, agent_payment_gateway)
#-everything in the job queue (queue and queue_arg)
#-business-onlinepayment and business-onlinepayment-ach config
use strict;
use vars qw( $opt_h );
use Getopt::Std;
use FS::UID qw(adminsuidsetup dbh);
use FS::Conf;
use FS::Schema qw(dbdef);
getopts('h');
adminsuidsetup shift;
foreach my $table (qw(
export_svc
part_export_option
part_export
payment_gateway
payment_gateway_option
agent_payment_gateway
queue
queue_arg
)) {
my $sth = dbh->prepare("DELETE FROM $table") or die dbh->errstr;
$sth->execute or die $sth->errstr;
}
my $dsth = dbh->prepare("DELETE FROM cust_main_invoice WHERE dest != 'POST'")
or die dbh->errstr;
$dsth->execute or die $dsth->errstr;
foreach my $table (qw( cust_main cust_payby
cust_pay_pending cust_pay cust_pay_void cust_pay_batch
cust_refund
)) {
my $ccsth = dbh->prepare("
UPDATE $table SET payinfo = '4111111111111111'
WHERE payby = 'CARD' OR payby = 'DCRD'
") or die dbh->errstr;
$ccsth->execute or die $ccsth->errstr;
}
my $sth = dbh->prepare("UPDATE part_event SET disabled = 'Y'");
$sth->execute or die $sth->errstr;
my $conf = new FS::Conf;
foreach my $item (qw(
business-onlinepayment
business-onlinepayment-ach
dump-localdest
dump-scpdest
cust_bill-ftp_spool
smtpmachine
)) {
$conf->delete($item);
}
if ($opt_h) { # not all history can be safely deleted
foreach my $table (grep { /^h_\w+$/ } dbdef->tables) {
my $sth = dbh->prepare("DELETE FROM $table") or die dbh->errstr;
$sth->execute or die $sth->errstr;
}
}
dbh->commit or die dbh->errstr;
|