Load XML-Feed-0.06 into trunk.
[catagits/XML-Feed.git] / lib / XML / Feed / Atom.pm
CommitLineData
973e1f9e 1# $Id: Atom.pm 1865 2005-08-09 20:15:31Z btrott $
0d5e38d1 2
3package XML::Feed::Atom;
4use strict;
5
6use base qw( XML::Feed );
7use XML::Atom::Feed;
8use XML::Atom::Util qw( iso2dt );
9use List::Util qw( first );
10
973e1f9e 11sub init_empty {
12 my $feed = shift;
13 $feed->{atom} = XML::Atom::Feed->new;
14 $feed;
15}
16
0d5e38d1 17sub init_string {
18 my $feed = shift;
19 my($str) = @_;
fe71566d 20 if ($str) {
21 $feed->{atom} = XML::Atom::Feed->new(Stream => $str)
22 or return $feed->error(XML::Atom::Feed->errstr);
23 }
0d5e38d1 24 $feed;
25}
26
27sub format { 'Atom' }
28
973e1f9e 29sub title { shift->{atom}->title(@_) }
0d5e38d1 30sub link {
973e1f9e 31 my $feed = shift;
32 if (@_) {
33 $feed->{atom}->add_link({ rel => 'alternate', href => $_[0],
34 type => 'text/html', });
35 } else {
36 my $l = first { $_->rel eq 'alternate' } $feed->{atom}->link;
37 $l ? $l->href : undef;
38 }
39}
40sub description { shift->{atom}->tagline(@_) }
41sub copyright { shift->{atom}->copyright(@_) }
42sub language { shift->{atom}->language(@_) }
43sub generator { shift->{atom}->generator(@_) }
44
45sub author {
46 my $feed = shift;
47 if (@_ && $_[0]) {
48 my $person = XML::Atom::Person->new;
49 $person->name($_[0]);
50 $feed->{atom}->author($person);
51 } else {
52 $feed->{atom}->author ? $feed->{atom}->author->name : undef;
53 }
54}
55
56sub modified {
57 my $feed = shift;
58 if (@_) {
59 $feed->{atom}->modified($_[0]->iso8601 . 'Z');
60 } else {
61 iso2dt($feed->{atom}->modified);
62 }
0d5e38d1 63}
0d5e38d1 64
65sub entries {
66 my @entries;
67 for my $entry ($_[0]->{atom}->entries) {
973e1f9e 68 push @entries, XML::Feed::Entry::Atom->wrap($entry);
0d5e38d1 69 }
70 @entries;
71}
72
973e1f9e 73sub add_entry {
74 my $feed = shift;
75 my($entry) = @_;
76 $feed->{atom}->add_entry($entry->unwrap);
77}
78
79sub as_xml { $_[0]->{atom}->as_xml }
80
81package XML::Feed::Entry::Atom;
0d5e38d1 82use strict;
83
84use base qw( XML::Feed::Entry );
85use XML::Atom::Util qw( iso2dt );
a749d9b9 86use XML::Feed::Content;
973e1f9e 87use XML::Atom::Entry;
0d5e38d1 88use List::Util qw( first );
89
973e1f9e 90sub init_empty {
91 my $entry = shift;
92 $entry->{entry} = XML::Atom::Entry->new;
93 1;
94}
95
96sub title { shift->{entry}->title(@_) }
0d5e38d1 97sub link {
973e1f9e 98 my $entry = shift;
99 if (@_) {
100 $entry->{entry}->add_link({ rel => 'alternate', href => $_[0],
101 type => 'text/html', });
102 } else {
103 my $l = first { $_->rel eq 'alternate' } $entry->{entry}->link;
104 $l ? $l->href : undef;
105 }
0d5e38d1 106}
a749d9b9 107
108sub summary {
973e1f9e 109 my $entry = shift;
110 if (@_) {
111 $entry->{entry}->summary(ref($_[0]) eq 'XML::Feed::Content' ?
112 $_[0]->body : $_[0]);
113 } else {
114 XML::Feed::Content->wrap({ type => 'text/html',
115 body => $entry->{entry}->summary });
116 }
a749d9b9 117}
118
119sub content {
973e1f9e 120 my $entry = shift;
121 if (@_) {
122 my %param;
123 if (ref($_[0]) eq 'XML::Feed::Content') {
124 %param = (Body => $_[0]->body, Type => $_[0]->type || 'text/html');
125 } else {
126 %param = (Body => $_[0], Type => 'text/html');
127 }
128 $entry->{entry}->content(XML::Atom::Content->new(%param));
129 } else {
130 my $c = $entry->{entry}->content;
131 XML::Feed::Content->wrap({ type => $c ? $c->type : undef,
132 body => $c ? $c->body : undef });
133 }
a749d9b9 134}
0d5e38d1 135
136sub category {
973e1f9e 137 my $entry = shift;
0d5e38d1 138 my $ns = XML::Atom::Namespace->new(dc => 'http://purl.org/dc/elements/1.1/');
973e1f9e 139 if (@_) {
140 $entry->{entry}->set($ns, 'subject', $_[0]);
141 } else {
142 $entry->{entry}->get($ns, 'subject');
143 }
144}
145
146sub author {
147 my $entry = shift;
148 if (@_ && $_[0]) {
149 my $person = XML::Atom::Person->new;
150 $person->name($_[0]);
151 $entry->{entry}->author($person);
152 } else {
153 $entry->{entry}->author ? $entry->{entry}->author->name : undef;
154 }
155}
156
157sub id { shift->{entry}->id(@_) }
158
159sub issued {
160 my $entry = shift;
161 if (@_) {
162 $entry->{entry}->issued($_[0]->iso8601 . 'Z') if $_[0];
163 } else {
164 $entry->{entry}->issued ? iso2dt($entry->{entry}->issued) : undef;
165 }
0d5e38d1 166}
167
973e1f9e 168sub modified {
169 my $entry = shift;
170 if (@_) {
171 $entry->{entry}->modified($_[0]->iso8601 . 'Z') if $_[0];
172 } else {
173 $entry->{entry}->modified ? iso2dt($entry->{entry}->modified) : undef;
174 }
175}
0d5e38d1 176
1771;