—package
RDF::vCard::Entity;
use
5.008;
use
common::sense;
our
$VERSION
=
'0.002'
;
sub
new
{
my
(
$class
,
%options
) =
@_
;
$options
{profile} ||=
'VCARD'
;
$options
{lines} ||= [];
$options
{components} ||= [];
bless
{
%options
},
$class
;
}
sub
profile
{
my
(
$self
) =
@_
;
return
$self
->{profile};
}
sub
lines
{
my
(
$self
) =
@_
;
return
$self
->{lines};
}
sub
components
{
my
(
$self
) =
@_
;
return
$self
->{components};
}
sub
add
{
my
(
$self
,
$line
) =
@_
;
push
@{
$self
->lines },
$line
;
$self
->_entity_order_fu(
$line
);
return
$self
;
}
sub
add_component
{
my
(
$self
,
$c
) =
@_
;
push
@{
$self
->components },
$c
;
return
$self
;
}
sub
get
{
my
(
$self
,
$property
) =
@_
;
return
grep
{
lc
$_
->property eq
lc
$property
} @{
$self
->lines };
}
sub
matches
{
my
(
$self
,
$property
,
$regexp
) =
@_
;
return
grep
{
$_
->value_to_string =~
$regexp
;
}
$self
->get(
$property
);
}
sub
entity_order
{
my
(
$self
) =
@_
;
return
$self
->{property}{
'sort-string'
}
||
$self
->{property}{
'n'
}
||
$self
->{property}{
'n-faked'
}
||
$self
->{property}{
'fn'
}
||
$self
->{property}{
'nickname'
};
}
sub
_entity_order_fu
{
my
(
$self
,
$line
) =
@_
;
if
(
$line
->property =~ /^(
sort
.string|n|fn|nickname)$/i)
{
my
$x
=
$line
->value_to_string;
$self
->{property}{
lc
$line
->property } =
$x
if
length
$x
;
if
(
lc
$line
->property eq
'fn'
)
{
my
@parts
=
split
/\s+/,
$x
;
my
$last
=
pop
@parts
;
unshift
@parts
,
$last
;
$self
->{property}{
'n-faked'
} =
join
';'
,
@parts
;
}
}
return
$self
;
}
sub
to_string
{
my
(
$self
) =
@_
;
my
@lines
=
sort
{
$a
->property_order cmp
$b
->property_order;
} @{
$self
->lines};
my
@components
=
sort
{
$a
->entity_order cmp
$b
->entity_order;
} @{
$self
->components};
my
$str
=
sprintf
(
"BEGIN:%s\r\n"
,
$self
->profile);
foreach
my
$line
(
@lines
)
{
$str
.=
$line
.
"\r\n"
;
}
foreach
my
$component
(
@components
)
{
$str
.=
$component
;
}
$str
.=
sprintf
(
"END:%s\r\n"
,
$self
->profile);
return
$str
;
}
1;
__END__
=head1 NAME
RDF::vCard::Entity - represents a single vCard
=head1 DESCRIPTION
Instances of this class correspond to individual vCard objects, though
it could potentially be used as basis for other RFC 2425-based formats
such as iCalendar.
=head2 Constructor
=over
=item * C<< new(%options) >>
Returns a new RDF::vCard::Entity object.
The only option worth worrying about is B<profile> which sets the
profile for the entity. This defaults to "VCARD".
RDF::vCard::Entity overloads stringification, so you can do the following:
my $vcard = RDF::vCard::Entity->new;
print $vcard if $vcard =~ /VCARD/i;
=back
=head2 Methods
=over
=item * C<< to_string() >>
Formats the object according to RFC 2425 and RFC 2426.
=item * C<< profile() >>
Returns the entity type - e.g. "VCARD".
=item * C<< lines() >>
Returns an arrayref of L<RDF::vCard::Line> objects in the order they
were originally added.
This excludes the "BEGIN:VCARD" and "END:VCARD" lines.
=item * C<< add($line) >>
Add a L<RDF::vCard::Line>.
=item * C<< entity_order() >>
Returns a string along the lines of "Surname;Forename" useful for
sorting a list of entities.
=item * C<< get($property) >>
Returns a list of L<RDF::vCard::Line> objects for the given property.
e.g.
print "It has an address!\n" if ($vcard->get('ADR'));
=item * C<< matches($property, $regexp) >>
Checks to see if a property's value matches a regular expression.
print "In London\n" if $vcard->matches(ADR => /London/);
=back
=head1 SEE ALSO
L<RDF::vCard::Exporter>, L<RDF::vCard::Line>.
=head1 AUTHOR
Toby Inkster E<lt>tobyink@cpan.orgE<gt>.
=head1 COPYRIGHT
Copyright 2011 Toby Inkster
This library is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.