1Email::Address::XS(3) User Contributed Perl DocumentationEmail::Address::XS(3)
2
3
4
6 Email::Address::XS - Parse and format RFC 5322 email addresses and
7 groups
8
10 use Email::Address::XS;
11
12 my $winstons_address = Email::Address::XS->new(phrase => 'Winston Smith', user => 'winston.smith', host => 'recdep.minitrue', comment => 'Records Department');
13 print $winstons_address->address();
14 # winston.smith@recdep.minitrue
15
16 my $julias_address = Email::Address::XS->new('Julia', 'julia@ficdep.minitrue');
17 print $julias_address->format();
18 # Julia <julia@ficdep.minitrue>
19
20 my $users_address = Email::Address::XS->parse('user <user@oceania>');
21 print $users_address->host();
22 # oceania
23
24 my $goldsteins_address = Email::Address::XS->parse_bare_address('goldstein@brotherhood.oceania');
25 print $goldsteins_address->user();
26 # goldstein
27
28 my @addresses = Email::Address::XS->parse('"Winston Smith" <winston.smith@recdep.minitrue> (Records Department), Julia <julia@ficdep.minitrue>');
29 # ($winstons_address, $julias_address)
30
31
32 use Email::Address::XS qw(format_email_addresses format_email_groups parse_email_addresses parse_email_groups);
33
34 my $addresses_string = format_email_addresses($winstons_address, $julias_address, $users_address);
35 # "Winston Smith" <winston.smith@recdep.minitrue> (Records Department), Julia <julia@ficdep.minitrue>, user <user@oceania>
36
37 my @addresses = map { $_->address() } parse_email_addresses($addresses_string);
38 # ('winston.smith@recdep.minitrue', 'julia@ficdep.minitrue', 'user@oceania')
39
40 my $groups_string = format_email_groups('Brotherhood' => [ $winstons_address, $julias_address ], undef() => [ $users_address ]);
41 # Brotherhood: "Winston Smith" <winston.smith@recdep.minitrue> (Records Department), Julia <julia@ficdep.minitrue>;, user <user@oceania>
42
43 my @groups = parse_email_groups($groups_string);
44 # ('Brotherhood' => [ $winstons_address, $julias_address ], undef() => [ $users_address ])
45
46
47 use Email::Address::XS qw(compose_address split_address);
48
49 my ($user, $host) = split_address('julia(outer party)@ficdep.minitrue');
50 # ('julia', 'ficdep.minitrue')
51
52 my $string = compose_address('charrington"@"shop', 'thought.police.oceania');
53 # "charrington\"@\"shop"@thought.police.oceania
54
56 This module implements RFC 5322 <https://tools.ietf.org/html/rfc5322>
57 parser and formatter of email addresses and groups. It parses an input
58 string from email headers which contain a list of email addresses or a
59 groups of email addresses (like From, To, Cc, Bcc, Reply-To, Sender,
60 ...). Also it can generate a string value for those headers from a list
61 of email addresses objects. Module is backward compatible with RFC 2822
62 <https://tools.ietf.org/html/rfc2822> and RFC 822
63 <https://tools.ietf.org/html/rfc822>.
64
65 Parser and formatter functionality is implemented in XS and uses shared
66 code from Dovecot IMAP server.
67
68 It is a drop-in replacement for the Email::Address module which has
69 several security issues. E.g. issue CVE-2015-7686 (Algorithmic
70 complexity vulnerability) <https://cve.mitre.org/cgi-
71 bin/cvename.cgi?name=CVE-2015-7686>, which allows remote attackers to
72 cause denial of service, is still present in Email::Address version
73 1.908.
74
75 Email::Address::XS module was created to finally fix CVE-2015-7686.
76
77 Existing applications that use Email::Address module could be easily
78 switched to Email::Address::XS module. In most cases only changing "use
79 Email::Address" to "use Email::Address::XS" and replacing every
80 "Email::Address" occurrence with "Email::Address::XS" is sufficient.
81
82 So unlike Email::Address, this module does not use regular expressions
83 for parsing but instead native XS implementation parses input string
84 sequentially according to RFC 5322 grammar.
85
86 Additionally it has support also for named groups and so can be use
87 instead of the Email::Address::List module.
88
89 If you are looking for the module which provides object representation
90 for the list of email addresses suitable for the MIME email headers,
91 see Email::MIME::Header::AddressList.
92
93 EXPORT
94 None by default. Exportable functions are: "parse_email_addresses",
95 "parse_email_groups", "format_email_addresses", "format_email_groups",
96 "compose_address", "split_address".
97
98 Exportable Functions
99 format_email_addresses
100 use Email::Address::XS qw(format_email_addresses);
101
102 my $winstons_address = Email::Address::XS->new(phrase => 'Winston Smith', address => 'winston@recdep.minitrue');
103 my $julias_address = Email::Address::XS->new(phrase => 'Julia', address => 'julia@ficdep.minitrue');
104 my @addresses = ($winstons_address, $julias_address);
105 my $string = format_email_addresses(@addresses);
106 print $string;
107 # "Winston Smith" <winston@recdep.minitrue>, Julia <julia@ficdep.minitrue>
108
109 Takes a list of email address objects and returns one formatted
110 string of those email addresses.
111
112 format_email_groups
113 use Email::Address::XS qw(format_email_groups);
114
115 my $winstons_address = Email::Address::XS->new(phrase => 'Winston Smith', user => 'winston.smith', host => 'recdep.minitrue');
116 my $julias_address = Email::Address::XS->new('Julia', 'julia@ficdep.minitrue');
117 my $users_address = Email::Address::XS->new(address => 'user@oceania');
118
119 my $groups_string = format_email_groups('Brotherhood' => [ $winstons_address, $julias_address ], undef() => [ $users_address ]);
120 print $groups_string;
121 # Brotherhood: "Winston Smith" <winston.smith@recdep.minitrue>, Julia <julia@ficdep.minitrue>;, user@oceania
122
123 my $undisclosed_string = format_email_groups('undisclosed-recipients' => []);
124 print $undisclosed_string;
125 # undisclosed-recipients:;
126
127 Like "format_email_addresses" but this method takes pairs which
128 consist of a group display name and a reference to address list. If
129 a group is not undef then address list is formatted inside named
130 group.
131
132 parse_email_addresses
133 use Email::Address::XS qw(parse_email_addresses);
134
135 my $string = '"Winston Smith" <winston.smith@recdep.minitrue>, Julia <julia@ficdep.minitrue>, user@oceania';
136 my @addresses = parse_email_addresses($string);
137 # @addresses now contains three Email::Address::XS objects, one for each address
138
139 Parses an input string and returns a list of Email::Address::XS
140 objects. Optional second string argument specifies class name for
141 blessing new objects.
142
143 parse_email_groups
144 use Email::Address::XS qw(parse_email_groups);
145
146 my $string = 'Brotherhood: "Winston Smith" <winston.smith@recdep.minitrue>, Julia <julia@ficdep.minitrue>;, user@oceania, undisclosed-recipients:;';
147 my @groups = parse_email_groups($string);
148 # @groups now contains list ('Brotherhood' => [ $winstons_object, $julias_object ], undef() => [ $users_object ], 'undisclosed-recipients' => [])
149
150 Like "parse_email_addresses" but this function returns a list of
151 pairs: a group display name and a reference to a list of addresses
152 which belongs to that named group. An undef value for a group
153 means that a following list of addresses is not inside any named
154 group. An output is in a same format as a input for the function
155 "format_email_groups". This function preserves order of groups and
156 does not do any de-duplication or merging.
157
158 compose_address
159 use Email::Address::XS qw(compose_address);
160 my $string_address = compose_address($user, $host);
161
162 Takes an unescaped user part and unescaped host part of an address
163 and returns escaped address.
164
165 Available since version 1.01.
166
167 split_address
168 use Email::Address::XS qw(split_address);
169 my ($user, $host) = split_address($string_address);
170
171 Takes an escaped address and split it into pair of unescaped user
172 part and unescaped host part of address. If splitting input address
173 into these two parts is not possible then this function returns
174 pair of undefs.
175
176 Available since version 1.01.
177
178 Class Methods
179 new
180 my $empty_address = Email::Address::XS->new();
181 my $winstons_address = Email::Address::XS->new(phrase => 'Winston Smith', user => 'winston.smith', host => 'recdep.minitrue', comment => 'Records Department');
182 my $julias_address = Email::Address::XS->new('Julia', 'julia@ficdep.minitrue');
183 my $users_address = Email::Address::XS->new(address => 'user@oceania');
184 my $only_name = Email::Address::XS->new(phrase => 'Name');
185 my $copy_of_winstons_address = Email::Address::XS->new(copy => $winstons_address);
186
187 Constructs and returns a new "Email::Address::XS" object. Takes
188 named list of arguments: phrase, address, user, host, comment and
189 copy. An argument address takes precedence over user and host.
190
191 When an argument copy is specified then it is expected an
192 Email::Address::XS object and a cloned copy of that object is
193 returned. All other parameters are ignored.
194
195 Old syntax from the Email::Address module is supported too. Takes
196 one to four positional arguments: phrase, address comment, and
197 original string. Passing an argument original is deprecated,
198 ignored and throws a warning.
199
200 parse
201 my $winstons_address = Email::Address::XS->parse('"Winston Smith" <winston.smith@recdep.minitrue> (Records Department)');
202 my @users_addresses = Email::Address::XS->parse('user1@oceania, user2@oceania');
203
204 Parses an input string and returns a list of an Email::Address::XS
205 objects. Same as the function "parse_email_addresses" but this one
206 is class method.
207
208 In scalar context this function returns just first parsed object.
209 If more then one object was parsed then "is_valid" method on
210 returned object returns false. If no object was parsed then empty
211 Email::Address::XS object is returned.
212
213 Prior to version 1.01 return value in scalar context is undef when
214 no object was parsed.
215
216 parse_bare_address
217 my $winstons_address = Email::Address::XS->parse_bare_address('winston.smith@recdep.minitrue');
218
219 Parses an input string as one bare email address (addr spec) which
220 does not allow phrase part or angle brackets around email address
221 and returns an Email::Address::XS object. It is just a wrapper
222 around "address" method. Method "is_valid" can be used to check if
223 parsing was successful.
224
225 Available since version 1.01.
226
227 Object Methods
228 format
229 my $string = $address->format();
230
231 Returns formatted Email::Address::XS object as a string. This
232 method throws a warning when "user" or "host" part of the email
233 address is invalid or empty string.
234
235 is_valid
236 my $is_valid = $address->is_valid();
237
238 Returns true if the parse function or method which created this
239 Email::Address::XS object had not received any syntax error on
240 input string and also that "user" and "host" part of the email
241 address are not empty strings.
242
243 Thus this function can be used for checking if Email::Address::XS
244 object is valid before calling "format" method on it.
245
246 Available since version 1.01.
247
248 phrase
249 my $phrase = $address->phrase();
250 $address->phrase('Winston Smith');
251
252 Accessor and mutator for the phrase (display name).
253
254 user
255 my $user = $address->user();
256 $address->user('winston.smith');
257
258 Accessor and mutator for the unescaped user (local/mailbox) part of
259 an address.
260
261 host
262 my $host = $address->host();
263 $address->host('recdep.minitrue');
264
265 Accessor and mutator for the unescaped host (domain) part of an
266 address.
267
268 Since version 1.03 this method checks if setting a new value is
269 syntactically valid. If not undef is set and returned.
270
271 address
272 my $string_address = $address->address();
273 $address->address('winston.smith@recdep.minitrue');
274
275 Accessor and mutator for the escaped address (addr spec).
276
277 Internally this module stores a user and a host part of an address
278 separately. Function "compose_address" is used for composing full
279 address and function "split_address" for splitting into a user and
280 a host parts. If splitting new address into these two parts is not
281 possible then this method returns undef and sets both parts to
282 undef.
283
284 comment
285 my $comment = $address->comment();
286 $address->comment('Records Department');
287
288 Accessor and mutator for the comment which is formatted after an
289 address. A comment can contain another nested comments in round
290 brackets. When setting new comment this method check if brackets
291 are balanced. If not undef is set and returned.
292
293 name
294 my $name = $address->name();
295
296 This method tries to return a name which belongs to the address. It
297 returns either "phrase" or "comment" or "user" part of the address
298 or empty string (first defined value in this order). But it never
299 returns undef.
300
301 as_string
302 my $address = Email::Address::XS->new(phrase => 'Winston Smith', address => 'winston.smith@recdep.minitrue');
303 my $stringified = $address->as_string();
304
305 This method is used for object stringification. It returns string
306 representation of object. By default object is stringified to
307 "format".
308
309 Available since version 1.01.
310
311 original
312 my $address = Email::Address::XS->parse('(Winston) "Smith" <winston.smith@recdep.minitrue> (Minitrue)');
313 my $original = $address->original();
314 # (Winston) "Smith" <winston.smith@recdep.minitrue> (Minitrue)
315 my $format = $address->format();
316 # Smith <winston.smith@recdep.minitrue> (Minitrue)
317
318 This method returns original part of the string which was used for
319 parsing current Email::Address::XS object. If object was not
320 created by parsing input string, then this method returns undef.
321
322 Note that "format" method does not have to return same original
323 string.
324
325 Available since version 1.01.
326
327 Overloaded Operators
328 stringify
329 my $address = Email::Address::XS->new(phrase => 'Winston Smith', address => 'winston.smith@recdep.minitrue');
330 print "Winston's address is $address.";
331 # Winston's address is "Winston Smith" <winston.smith@recdep.minitrue>.
332
333 Stringification is done by method "as_string".
334
335 Deprecated Functions and Variables
336 For compatibility with the Email::Address module there are defined some
337 deprecated functions and variables. Do not use them in new code. Their
338 usage throws warnings.
339
340 Altering deprecated variable $Email::Address::XS::STRINGIFY changes
341 method which is called for objects stringification.
342
343 Deprecated cache functions "purge_cache", "disable_cache" and
344 "enable_cache" are noop and do nothing.
345
347 RFC 822 <https://tools.ietf.org/html/rfc822>, RFC 2822
348 <https://tools.ietf.org/html/rfc2822>, RFC 5322
349 <https://tools.ietf.org/html/rfc5322>,
350 Email::MIME::Header::AddressList, Email::Address, Email::Address::List,
351 Email::AddressParser
352
354 Pali <pali@cpan.org>
355
357 Copyright (C) 2015-2018 by Pali <pali@cpan.org>
358
359 This library is free software; you can redistribute it and/or modify it
360 under the same terms as Perl itself, either Perl version 5.6.0 or, at
361 your option, any later version of Perl 5 you may have available.
362
363 Dovecot parser is licensed under The MIT License and copyrighted by
364 Dovecot authors.
365
366
367
368perl v5.34.0 2021-07-22 Email::Address::XS(3)