X-Git-Url: http://git.rot13.org/?p=angular-mojolicious.git;a=blobdiff_plain;f=angular-server.pl;h=57e40a475957de8dc64029e6d2de748b92f8d4f2;hp=d8d9b9e03a9a1c561c01f0a97e22c77eed62b1f1;hb=9491349ff907e6fb0ad15125ce375318457de7b8;hpb=44d7eda441beeed6c049531dee2b752bd920852e diff --git a/angular-server.pl b/angular-server.pl index d8d9b9e..57e40a4 100755 --- a/angular-server.pl +++ b/angular-server.pl @@ -182,6 +182,54 @@ 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"; + my $data = Mojo::JSON->new->decode( $str ); + $data->{_key} = $1 if $path =~ m{/([^/]+$)}; + push @$docs, $data; + } + + _render_jsonp( $self, $docs ) +}; + app->start; __DATA__