aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authordakkar <dakkar@thenautilus.net>2017-02-14 22:22:56 +0000
committerdakkar <dakkar@thenautilus.net>2017-02-14 22:22:56 +0000
commit714da2b50f0b027abe4b5b759c5fa3bbd3815089 (patch)
tree449103c1c56e346c935e9c7d996709d31cddb083 /lib
parentmore POD (diff)
downloadSietima-714da2b50f0b027abe4b5b759c5fa3bbd3815089.tar.gz
Sietima-714da2b50f0b027abe4b5b759c5fa3bbd3815089.tar.bz2
Sietima-714da2b50f0b027abe4b5b759c5fa3bbd3815089.zip
new role: ManualSubscription
Diffstat (limited to 'lib')
-rw-r--r--lib/Sietima.pm2
-rw-r--r--lib/Sietima/Role/ManualSubscription.pm53
2 files changed, 55 insertions, 0 deletions
diff --git a/lib/Sietima.pm b/lib/Sietima.pm
index e317147..98859ab 100644
--- a/lib/Sietima.pm
+++ b/lib/Sietima.pm
@@ -51,6 +51,8 @@ prevents the sender from receiving copies of their own messages
avoids mail-loops using a C<X-Been-There> header
= L<< C<Headers>|Sietima::Role::Headers >>
adds C<List-*> headers to all outgoing messages
+= L<< C<ManualSubscription>|Sietima::Role::ManualSubscription >>
+specifies that to (un)subscribe, people should write to the list owner
= L<< C<NoMail>|Sietima::Role::NoMail >>
avoids sending messages to subscribers who don't want them
= L<< C<ReplyTo>|Sietima::Role::ReplyTo >>
diff --git a/lib/Sietima/Role/ManualSubscription.pm b/lib/Sietima/Role/ManualSubscription.pm
new file mode 100644
index 0000000..fd75f80
--- /dev/null
+++ b/lib/Sietima/Role/ManualSubscription.pm
@@ -0,0 +1,53 @@
+package Sietima::Role::ManualSubscription;
+use Moo::Role;
+use Sietima::Policy;
+use URI;
+use namespace::clean;
+
+# VERSION
+# ABSTRACT: adds standard list-related headers to messages
+
+with 'Sietima::Role::WithOwner';
+
+=head1 SYNOPSIS
+
+ my $sietima = Sietima->with_traits(
+ 'Headers',
+ 'ManualSubscription',
+ )->new({
+ %args,
+ owner => 'listmaster@example.com',
+ });
+
+=head1 DESCRIPTION
+
+A L<< C<Sietima> >> list with this role (and L<<
+C<Headers>|Sietima::Role::Headers >>) applied will add, to each
+outgoing message, headers specifying that to subscribe and
+unsubscribe, people sould email the list owner.
+
+=modif C<list_addresses>
+
+This method declares two "addresses", C<subscribe> and
+C<unsubscribe>. Both are C<mailto:> URLs for the list
+L<owner|Sietima::Role::WithOwner/owner>, with different subjects.
+
+=cut
+
+around list_addresses => sub($orig,$self) {
+ my $list_name = $self->name // 'the list';
+ my $mail_owner_uri = URI->new($self->owner,'mailto');
+ my $sub_uri = $mail_owner_uri->clone;
+ $sub_uri->query_form(subject => "Please add me to $list_name");
+ my $unsub_uri = $mail_owner_uri->clone;
+ $unsub_uri->query_form(subject => "Please remove me from $list_name");
+
+ return +{
+ $self->$orig->%*,
+ subscribe => $sub_uri,
+ unsubscribe => $unsub_uri,
+ };
+};
+
+
+1;