From: Dobrica Pavlinusic Date: Sun, 28 Nov 2010 13:03:04 +0000 (+0100) Subject: static JSON files from public/json/database/entity/json X-Git-Url: http://git.rot13.org/?p=angular-mojolicious.git;a=commitdiff_plain;h=2137d2680d5cd2d8ed400e3120406ad146028210 static JSON files from public/json/database/entity/json --- diff --git a/angular-server.pl b/angular-server.pl index d8d9b9e..0ac4544 100755 --- a/angular-server.pl +++ b/angular-server.pl @@ -182,6 +182,52 @@ get '/:database/_design/:design/_view/:view' => sub { _render_jsonp( $self, _couchdb_get($url)); }; +# static JSON files from public/json/database/entity/json + +get '/json' => sub { + _render_jsonp( shift, [ map { s{public/json/}{}; $_ } glob 'public/json/*' ] ); +}; + +get '/json/:database' => sub { + my $self = shift; + my $database = $self->param('database'); + + my $status = { + document_counts => 0, + name => $database, + }; + + foreach my $path ( glob "public/json/$database/*" ) { + my @entities = glob "$path/*"; + $path =~ s{public/json/$database/}{}; + $status->{entities}->{$path} = scalar @entities; + $status->{document_counts}++; + } + + _render_jsonp( $self, $status ); +}; + +get '/json/:database/:entity' => sub { + my $self = shift; + + my $database = $self->param('database'); + my $entity = $self->param('entity'); + + my $path = "public/json/$database/$entity"; + die "$path: $!" unless -d $path; + + my $docs; + foreach my $path ( sort glob "$path/*" ) { + open(my $fh, '<', $path) || die $!; + local $/ = undef; + my $str = <$fh>; + warn "# $path $str"; + push @$docs, Mojo::JSON->new->decode( $str ); + } + + _render_jsonp( $self, $docs ) +}; + app->start; __DATA__