$json->{'_'.$_} = $new->{$_} foreach ( 'rev','id' );
} else {
warn "ERROR: ",dump($new);
- $json->{_error} = $new;
+ $json->{error} = $new;
}
_render_jsonp( $self, $json );
_render_jsonp( $self, $docs )
};
+# app/resevations
+use Encode;
+use iCal::Parser;
+
+plugin 'proxy';
+
+my $slot_regex = '(\d+)\s*mjesta';
+
+get '/reservations/get/(*url)' => sub {
+ my $self = shift;
+
+ my $text = $client->get( 'http://' . $self->param('url') )->res->body;
+ warn "# get ", $self->param('url'), dump($text);
+
+ $text = decode( 'utf-8', $text );
+ $text =~ s{\\,}{,}gs;
+ $text =~ s{\\n}{ }gs;
+
+ my $c = iCal::Parser->new->parse_strings( $text );
+
+# warn "# iCal::Parser = ",dump($c);
+
+ my $ical = {
+ cal => $c->{cals}->[0], # FIXME assume single calendar
+ };
+
+ my $e = $c->{events};
+ my @events;
+
+ foreach my $yyyy ( sort keys %$e ) {
+ foreach my $mm ( sort keys %{ $e->{$yyyy} } ) {
+ foreach my $dd ( sort keys %{ $e->{$yyyy}->{$mm} } ) {
+ push @events, values %{ $e->{$yyyy}->{$mm}->{$dd} };
+ }
+ }
+ }
+
+ @events = map {
+ foreach my $check_slot ( qw(
+ DESCRIPTION
+ LOCATION
+ STATUS
+ SUMMARY
+ )) {
+ next unless exists $_->{$check_slot};
+ $_->{slots} = $1 if $_->{$check_slot} =~ m/$slot_regex/is;
+ }
+ $_->{slots} ||= $1 if $ical->{cal}->{'X-WR-CALDESC'} =~ m/$slot_regex/s;
+ $_->{slots} ||= 15; # XXX default number of slots
+ $_;
+ } @events;
+
+ $ical->{events} = [ sort {
+ $a->{DTSTART} cmp $b->{DTSTART}
+ } @events ];
+
+ _render_jsonp( $self, $ical );
+};
+
+get '/reservations/events/:view_name' => sub {
+ my $self = shift;
+
+ my $view = _couchdb_get('/reservations/_design/events/_view/' . $self->param('view_name') . '?group=true');
+ my $hash;
+
+ if ( exists $view->{error} ) {
+ _couchdb_put "/reservations/_design/events", {
+ _id => '_design/events',
+ language => 'javascript',
+ views => {
+ submited => {
+ map => q|(
+ function(doc) {
+ if ( doc.event && doc.event.UID ) emit(doc.event.UID, 1)
+ }
+ )|,
+ reduce => q|_sum|,
+ }
+ }
+ };
+ }
+
+ _render_jsonp( $self, {} ) unless ref $view->{rows} eq 'ARRAY';
+
+ foreach my $row ( @{ $view->{rows} } ) {
+ $hash->{ $row->{key} } = $row->{value};
+ }
+
+ $hash ||= {};
+
+ _render_jsonp( $self, $hash );
+};
+
+get '/_utils/script/(*url)' => sub { $_[0]->proxy_to( "$couchdb/_utils/script/" . $_[0]->param('url') , with_query_params => 1 ) };
+
app->start;
__DATA__