summary refs log tree commit diff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/jitterbug.pm24
-rw-r--r--lib/jitterbug/Hook.pm42
-rw-r--r--lib/jitterbug/Plugin/Redis.pm21
-rw-r--r--lib/jitterbug/Project.pm57
-rw-r--r--lib/jitterbug/WebService.pm34
5 files changed, 178 insertions, 0 deletions
diff --git a/lib/jitterbug.pm b/lib/jitterbug.pm
new file mode 100644
index 0000000..47c186e
--- /dev/null
+++ b/lib/jitterbug.pm
@@ -0,0 +1,24 @@
+package jitterbug;
+
+BEGIN {
+    use Dancer ':syntax';
+    load_plugin 'jitterbug::Plugin::Redis';
+};
+
+our $VERSION = '0.1';
+
+load_app 'jitterbug::Hook',       prefix => '/hook';
+load_app 'jitterbug::Project',    prefix => '/project';
+load_app 'jitterbug::WebService', prefix => '/api';
+
+before_template sub {
+    my $tokens = shift;
+    $tokens->{uri_base} = request->base;
+};
+
+get '/' => sub {
+    my @projects = redis->smembers(key_projects);
+    template 'index', {projects => \@projects};
+};
+
+true;
diff --git a/lib/jitterbug/Hook.pm b/lib/jitterbug/Hook.pm
new file mode 100644
index 0000000..ae17b4b
--- /dev/null
+++ b/lib/jitterbug/Hook.pm
@@ -0,0 +1,42 @@
+package jitterbug::Hook;
+
+BEGIN {
+    use Dancer ':syntax';
+    load_plugin 'jitterbug::Plugin::Redis';
+};
+
+setting serializer => 'JSON';
+
+post '/' => sub {
+    my $hook = from_json(params->{payload});
+
+    my $repo = $hook->{repository}->{name};
+
+    my $repo_key = key_project($repo);
+
+    if ( !redis->exists($repo_key) ) {
+        my $project = {
+            name        => $repo,
+            url         => $hook->{repository}->{url},
+            description => $hook->{repository}->{description},
+            owner       => $hook->{repository}->{owner},
+        };
+        redis->set( $repo_key, to_json($project) );
+        redis->sadd(key_projects, $repo);
+    }
+
+    my $last_commit = pop @{ $hook->{commits} };
+
+    $last_commit->{repo}    = $hook->{repository}->{url};
+    $last_commit->{project} = $repo;
+    $last_commit->{compare} = $hook->{compare};
+
+    my $task_key = key_task_repo($repo);
+    redis->set($task_key, to_json($last_commit));
+
+    redis->sadd(key_tasks, $task_key);
+
+    { updated => $repo };
+};
+
+1;
diff --git a/lib/jitterbug/Plugin/Redis.pm b/lib/jitterbug/Plugin/Redis.pm
new file mode 100644
index 0000000..d2be756
--- /dev/null
+++ b/lib/jitterbug/Plugin/Redis.pm
@@ -0,0 +1,21 @@
+package jitterbug::Plugin::Redis;
+
+use Dancer::Config qw/setting/;
+use Dancer::Plugin;
+use Redis;
+
+register redis => sub {
+    Redis->new( server => setting('redis') );
+};
+
+sub _key { join( ':', 'jitterbug', @_ ); }
+
+register key_projects       => sub { _key('projects'); };
+register key_project        => sub { _key('project', @_); };
+register key_builds_project => sub { _key('builds', @_); };
+register key_task_repo      => sub { _key('tasks', @_); };
+register key_tasks          => sub { _key('tasks'); };
+
+register_plugin;
+
+1;
diff --git a/lib/jitterbug/Project.pm b/lib/jitterbug/Project.pm
new file mode 100644
index 0000000..904ebf9
--- /dev/null
+++ b/lib/jitterbug/Project.pm
@@ -0,0 +1,57 @@
+package jitterbug::Project;
+
+BEGIN {
+    use Dancer ':syntax';
+    load_plugin 'jitterbug::Plugin::Redis';
+};
+
+use DateTime;
+use XML::Feed;
+
+get '/:project' => sub {
+    my $project = params->{project};
+
+    my $res = redis->get( key_project($project) );
+
+    send_error( "Project $project not found", 404 ) if !$res;
+
+    my $desc = from_json($res);
+
+    my @ids = redis->smembers( key_builds_project($project) );
+
+    my @builds;
+    foreach my $id (@ids) {
+        my $res = redis->get($id);
+        push @builds, from_json($res) if $res;
+    }
+
+    template 'project/index',
+      { project => $project, builds => \@builds, %$desc };
+};
+
+get '/:project/feed' => sub {
+    my $project = params->{project};
+
+    my @builds = reverse( redis->smembers( key_builds_project($project) ) );
+
+    my $feed = XML::Feed->new('Atom');
+    $feed->title('builds for '.$project);
+
+    foreach (splice(@builds, 0, 5)) {
+        my $res = redis->get($_);
+        next unless $res;
+        my $desc = from_json($res);
+
+        foreach my $version (keys %{$desc->{version}}) {
+            my $entry = XML::Feed::Entry->new();
+            $entry->title("build for ".$desc->{commit}.' on '.$version);
+            $entry->summary("Result: ".$desc->{version}->{$version});
+            $feed->add_entry($entry);
+        }
+    }
+
+    content_type('application/atom+xml');
+    $feed->as_xml;
+};
+
+1;
diff --git a/lib/jitterbug/WebService.pm b/lib/jitterbug/WebService.pm
new file mode 100644
index 0000000..4f89be8
--- /dev/null
+++ b/lib/jitterbug/WebService.pm
@@ -0,0 +1,34 @@
+package jitterbug::WebService;
+
+BEGIN {
+    use Dancer ':syntax';
+    load_plugin 'jitterbug::Plugin::Redis';
+}
+
+use File::Spec;
+
+set serializer => 'JSON';
+
+get '/build/:project/:commit/:version' => sub {
+    my $project = params->{project};
+    my $commit  = params->{commit};
+    my $version = params->{version};
+
+    my $conf = setting 'jitterbug';
+
+    my $file = File::Spec->catfile( $conf->{reports}->{dir},
+        $project, $commit, $version . '.txt' );
+
+    if ( -f $file ) {
+        open my $fh, '<', $file;
+        my @content = <$fh>;
+        close $fh;
+        {
+            commit  => $commit,
+            version => $version,
+            content => join( '', @content ),
+        };
+    }
+};
+
+1;