X-Git-Url: http://git.rot13.org/?p=angular-mojolicious.git;a=blobdiff_plain;f=angular-server.pl;h=30a99b9d56381f87f3a6d6a12154925ef4151891;hp=f91d8f5ccdce27a8419062b1510fed1d8c17bcbf;hb=7e72f290040ac6ee65d0e3db2842430c81f1c050;hpb=eeddd4aab1dfbbcc04ffd5c2509e20c841ad5003 diff --git a/angular-server.pl b/angular-server.pl index f91d8f5..30a99b9 100755 --- a/angular-server.pl +++ b/angular-server.pl @@ -7,63 +7,114 @@ use Data::Dump qw(dump); # http://docs.getangular.com/REST.Basic # http://angular.getangular.com/data -our $data; +our $data = { + 'Cookbook' => { + test => [ + { '$id' => 1, foo => 1, bar => 2, baz => 3 }, + { '$id' => 2, foo => 1 }, + { '$id' => 3, bar => 2 }, + { '$id' => 4, baz => 3 }, + ], + } +}; +our $id2nr; + +sub _render_jsonp { + my ( $self, $json ) = @_; + my $data = $self->render( json => $json, partial => 1 ); + if ( my $callback = $self->param('callback') ) { + $data = "$callback($data)"; + } + $self->render( data => $data, format => 'js' ); +} get '/' => 'index'; -get '/replicate' => sub { +get '/_replicate' => sub { my $self = shift; if ( my $from = $self->param('from') ) { my $got = $self->client->get( $from )->res->json; warn "# from $from ",dump($got); - $self->render_json( $got ); + _render_jsonp( $self, $got ); my $database = $got->{name}; my $entities = $got->{entities}; if ( $database && $entities ) { foreach my $entity ( keys %$entities ) { - my $e = $self->client->get( "$from/$entity" )->res->json; - warn "# replicated $entity ", dump($e); + my $url = $from; + $url =~ s{/?$}{/}; # add slash at end + $url .= $entity; + my $e = $self->client->get( $url )->res->json; + warn "# replicated $url ", dump($e); $data->{$database}->{$entity} = $e; + delete $id2nr->{$database}->{$entity}; } } } }; +get '/_data' => sub { + my $self = shift; + _render_jsonp( $self, $data ) +}; + get '/data/' => sub { my $self = shift; - $self->render_json( [ keys %$data ] ); + _render_jsonp( $self, [ keys %$data ] ); }; get '/data/:database' => sub { my $self = shift; my $database = $self->param('database'); my $list_databases = { name => $database }; - foreach my $database ( keys %{ $data->{ $database }} ) { - my $count = scalar keys %{ $data->{$database} }; - $list_databases->{entities}->{$database} = $count; + foreach my $entity ( keys %{ $data->{ $database }} ) { +warn "# entry $entity ", dump( $data->{$database}->{$entity} ); + my $count = $#{ $data->{$database}->{$entity} } + 1; + $list_databases->{entities}->{$entity} = $count; $list_databases->{document_count} += $count; } warn dump($list_databases); - $self->render_json( $list_databases ); + _render_jsonp( $self, $list_databases ); }; get '/data/:database/:entity' => sub { my $self = shift; - + _render_jsonp( $self, $data->{ $self->param('database') }->{ $self->param('entity' ) } ); }; get '/data/:database/:entity/:id' => sub { my $self = shift; + my $database = $self->param('database'); + my $entity = $self->param('entity'); + my $id = $self->param('id'); + + my $e = $data->{$database}->{$entity} || die "no entity $entity"; + + if ( ! defined $id2nr->{$database}->{$entity} ) { + foreach my $i ( 0 .. $#$e ) { + $id2nr->{$database}->{$entity}->{ $e->[$i]->{'$id'} } = $i; + } + } + + if ( exists $id2nr->{$database}->{$entity}->{$id} ) { + my $nr = $id2nr->{$database}->{$entity}->{$id}; + warn "# entity $id -> $nr\n"; + _render_jsonp( $self, $data->{$database}->{$entity}->[$nr] ); + } else { + die "no entity $entity $id in ", dump( $id2nr->{$database}->{$entity} ); + } }; -any [ 'put' ] => '/data/:database/:entity/:id' => sub { +any [ 'put', 'post' ] => '/data/:database/:entity/:id' => sub { my $self = shift; - $data->{ $self->param('database') }->{ $self->param('entity') }->{ $self->param('id') } = $self->req->json; - dumper $data; + my $data = $self->req->json; + warn "# body ",dump($self->req->body, $data); + die "no data" unless $data; + $data->{ $self->param('database') }->{ $self->param('entity') }->{ $self->param('id') } = $data; + _render_jsonp( $self, $data ); }; get '/demo/:groovy' => sub { @@ -71,6 +122,12 @@ get '/demo/:groovy' => sub { $self->render(text => $self->param('groovy'), layout => 'funky'); }; +get '/Cookbook' => 'Cookbook'; +get '/Cookbook/:example' => sub { + my $self = shift; + $self->render( "Cookbook/" . $self->param('example'), layout => 'angular' ); +}; + app->start; __DATA__ @@ -84,3 +141,13 @@ Yea baby! Funky! <%== content %> + +@@ layouts/angular.html.ep + + + + + + <%== content %> +