exact match, RT#3196
[freeside.git] / FS / bin / freeside-cdrrewrited
1 #!/usr/bin/perl -w
2
3 use strict;
4 use vars qw( $conf );
5 use FS::Daemon ':all'; #daemonize1 drop_root daemonize2 myexit logfile sig*
6 use FS::UID qw( adminsuidsetup );
7 use FS::Record qw( qsearch ); #qsearchs);
8 #use FS::cdr;
9 #use FS::cust_pkg;
10 #use FS::queue;
11
12 my $user = shift or die &usage;
13
14 #daemonize1('freeside-sprepaidd', $user); #keep unique pid files w/multi installs
15 daemonize1('freeside-cdrrewrited');
16
17 drop_root();
18
19 adminsuidsetup($user);
20
21 logfile( "%%%FREESIDE_LOG%%%/cdrrewrited-log.". $FS::UID::datasrc );
22
23 daemonize2();
24
25 $conf = new FS::Conf;
26
27 die "not running; cdr-asterisk_forward_rewrite conf is off\n"
28   unless _shouldrun();
29
30 #--
31
32 while (1) {
33
34   #hmm... don't want to do an expensive search with an ever-growing bunch
35   # of unprocessed CDRs during the month... better to mark them all as
36   # rewritten "skipped", i.e. why we're a daemon in the first place
37   # instead of just doing this search like normal CDRs
38
39   my $found = 0;
40   foreach my $cdr ( 
41     qsearch( {
42       'table'     => 'cdr',
43       'extra_sql' => 'FOR UPDATE',
44       'hashref'   => {},
45       'extra_sql' => 'WHERE freesidestatus IS NULL'.
46                      ' AND freesiderewritestatus IS NULL'.
47                      ' LIMIT 1024', #arbitrary, but don't eat too much memory
48     } )
49   ) {
50
51     $found = 1;
52
53     if ( $cdr->dstchannel =~ /^Local\/(\d+)/i && $1 ne $cdr->dst
54        )
55     {
56
57       my $dst = $1;
58
59       warn "dst ". $cdr->dst. " does not match dstchannel $dst ".
60            "(". $cdr->dstchannel. "); rewriting CDR as a forwarded call";
61
62       $cdr->charged_party($cdr->dst);
63       $cdr->dst($dst);
64       $cdr->amaflags(2);
65
66       $cdr->freesiderewritestatus('asterisk_forward');
67
68     } else {
69       $cdr->freesiderewritestatus('skipped')
70     }
71
72     my $error = $cdr->replace;
73
74     if ( $error ) {
75       warn "WARNING: error rewriting CDR (will retry in 30 seconds):".
76            " $error\n";
77       sleep 30; #i dunno, wait and see if the database comes back?
78     }
79
80   }
81
82   myexit() if sigterm() || sigint();
83   #sleep 1 unless $found;
84   sleep 5 unless $found;
85
86 }
87
88 #--
89
90 sub _shouldrun {
91   $conf->exists('cdr-asterisk_forward_rewrite');
92 }
93
94 sub usage { 
95   die "Usage:\n\n  freeside-cdrrewrited user\n";
96 }
97
98 =head1 NAME
99
100 freeside-cdrrewrited - Real-time daemon for CDR rewriting
101
102 =head1 SYNOPSIS
103
104   freeside-cdrrewrited
105
106 =head1 DESCRIPTION
107
108 Runs continuously, searches for CDRs and does forwarded-call rewriting if
109 the "cdr-asterisk_forward_rewrite" option is enabled.
110
111 =head1 SEE ALSO
112
113 =cut
114
115 1;