initial import
[catagits/Catalyst-Plugin-ConfigLoader.git] / lib / Catalyst / Plugin / ConfigLoader / JSON.pm
CommitLineData
b2d85594 1package Catalyst::Plugin::ConfigLoader::JSON;\r
2\r
3use strict;\r
4use warnings;\r
5\r
6use File::Slurp;\r
7\r
8=head1 NAME\r
9\r
10Catalyst::Plugin::ConfigLoader::JSON - Load JSON config files\r
11\r
12=head1 DESCRIPTION\r
13\r
14Loads JSON files. Example:\r
15\r
16 {\r
17 "name": "TestApp",\r
18 "Controller::Config": {\r
19 "foo": "bar"\r
20 }\r
21 }\r
22\r
23=head1 METHODS\r
24\r
25=head2 load( $file )\r
26\r
27Attempts to load C<$file> as a JSON file.\r
28\r
29=cut\r
30\r
31sub load {\r
32 my $class = shift;\r
33 my $confpath = shift;\r
34\r
35 my @files;\r
36 if( $confpath =~ /\.(.{3,4})$/ ) {\r
37 return unless $1 =~ /^jso?n$/;\r
38 @files = $confpath;\r
39 }\r
40 else {\r
41 @files = map { "$confpath.$_" } qw( json jsn );\r
42 }\r
43 \r
44 for my $file ( @files ) {\r
45 next unless -f $file;\r
46 \r
47 my $content = read_file( $file );\r
48\r
49 eval { require JSON::Syck; };\r
50 if( $@ ) {\r
51 require JSON;\r
52 JSON->import;\r
53 return jsonToObj( $content );\r
54 }\r
55 else {\r
56 return JSON::Syck::Load( $content );\r
57 }\r
58 }\r
59}\r
60\r
61=head1 AUTHOR\r
62\r
63=over 4 \r
64\r
65=item * Brian Cassidy E<lt>bricas@cpan.orgE<gt>\r
66\r
67=back\r
68\r
69=head1 COPYRIGHT AND LICENSE\r
70\r
71Copyright 2006 by Brian Cassidy\r
72\r
73This library is free software; you can redistribute it and/or modify\r
74it under the same terms as Perl itself. \r
75\r
76=head1 SEE ALSO\r
77\r
78=over 4 \r
79\r
80=item * L<Catalyst>\r
81\r
82=back\r
83\r
84=cut\r
85\r
861;