summaryrefslogtreecommitdiff
path: root/FS/FS/API.pm
diff options
context:
space:
mode:
authorMitch Jackson <mitch@freeside.biz>2018-02-13 20:44:18 -0600
committerMitch Jackson <mitch@freeside.biz>2018-02-13 20:44:18 -0600
commite4829d1025798f30b0af30d1e22da2f7c769df31 (patch)
treebab8592dbc4b5abe4bb93d71bd35d9b412287e69 /FS/FS/API.pm
parentd2b55d07a9e6e64a38877136d7974ab93e14f1ed (diff)
RT# 77217 Add email_opt_out action to API
Diffstat (limited to 'FS/FS/API.pm')
-rw-r--r--FS/FS/API.pm68
1 files changed, 68 insertions, 0 deletions
diff --git a/FS/FS/API.pm b/FS/FS/API.pm
index 75948a3..33c4775 100644
--- a/FS/FS/API.pm
+++ b/FS/FS/API.pm
@@ -10,6 +10,7 @@ use FS::cust_pay;
use FS::cust_credit;
use FS::cust_refund;
use FS::cust_pkg;
+use FS::cust_contact;
=head1 NAME
@@ -794,6 +795,8 @@ Including this implements per-customer custom pricing for this package, overridi
A single string for just one detail line, or an array reference of one or more
lines of detail
+=back
+
=cut
sub order_package {
@@ -1201,6 +1204,66 @@ sub edit_advertising_source {
}
+=item email_optout OPTION => VALUE, ...
+
+Each e-mail address, or L<FS::cust_contact> record, has two opt-in flags:
+message_dest: recieve non-invoicing messages, and invoice_dest: recieve
+invoicing messages
+
+Use this API call to remove opt-in flags for an e-mail address
+
+=over 4
+
+=item address
+
+E-Mail address
+
+=item disable_message_dest
+
+Enabled by default:
+Set this parameter as 0 in your API call to leave the message_dest flag as is
+
+=item disable_invoice_dest
+
+Enabled by default:
+Set this parameter as 0 in your API call to leave the invoice_dest flag as is
+
+=back
+
+=cut
+
+sub email_opt_out {
+ my ($class, %opt) = @_;
+
+ return _shared_secret_error()
+ unless _check_shared_secret($opt{secret});
+
+ return {error => 'No e-mail address specified'}
+ unless $opt{address} && $opt{address} =~ /\@/;
+
+ $opt{disable_message_dest} ||= 1;
+ $opt{disable_invoice_dest} ||= 1;
+
+ my $address = FS::Record::dbh->quote($opt{address});
+
+ for my $cust_contact (
+ FS::Record::qsearch({
+ table => 'cust_contact',
+ select => 'cust_contact.*',
+ addl_from => 'LEFT JOIN contact_email USING (contactnum)',
+ extra_sql => "WHERE contact_email.emailaddress = $address",
+ })
+ ) {
+ $cust_contact->set(invoice_dest => '') if $opt{disable_invoice_dest};
+ $cust_contact->set(message_dest => '') if $opt{disable_message_dest};
+
+ my $error = $cust_contact->replace();
+ return {error => $error} if $error;
+ }
+ return;
+}
+
+
##
# helper subroutines
##
@@ -1213,4 +1276,9 @@ sub _shared_secret_error {
return { 'error' => 'Incorrect shared secret' };
}
+
+=back
+
+=cut
+
1;