initial import
[catagits/Catalyst-Plugin-ConfigLoader.git] / lib / Catalyst / Plugin / ConfigLoader / JSON.pm
1 package Catalyst::Plugin::ConfigLoader::JSON;\r
2 \r
3 use strict;\r
4 use warnings;\r
5 \r
6 use File::Slurp;\r
7 \r
8 =head1 NAME\r
9 \r
10 Catalyst::Plugin::ConfigLoader::JSON - Load JSON config files\r
11 \r
12 =head1 DESCRIPTION\r
13 \r
14 Loads 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
27 Attempts to load C<$file> as a JSON file.\r
28 \r
29 =cut\r
30 \r
31 sub 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
71 Copyright 2006 by Brian Cassidy\r
72 \r
73 This library is free software; you can redistribute it and/or modify\r
74 it 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
86 1;