about summary refs log tree commit diff
diff options
context:
space:
mode:
authorfranck cuny <franck@lumberjaph.net>2010-04-13 18:46:54 +0200
committerfranck cuny <franck@lumberjaph.net>2010-04-13 18:46:54 +0200
commitd18213e3c6956540e21d738b411b00e9eb71dc4e (patch)
tree784913af63e25499c89033682b2caccfc2d000dd
parentinitial commit (diff)
downloadpresque-d18213e3c6956540e21d738b411b00e9eb71dc4e.tar.gz
basic REST job queue using tatsumaki + redis
-rw-r--r--app.psgi11
-rw-r--r--conf.yaml4
-rw-r--r--lib/presque.pm38
-rw-r--r--lib/presque/Backend/Redis.pm0
-rw-r--r--lib/presque/IndexHandler.pm14
-rw-r--r--lib/presque/JobQueueHandler.pm13
-rw-r--r--lib/presque/RestQueueHandler.pm81
7 files changed, 159 insertions, 2 deletions
diff --git a/app.psgi b/app.psgi
new file mode 100644
index 0000000..9473ea3
--- /dev/null
+++ b/app.psgi
@@ -0,0 +1,11 @@
+#!/usr/bin/perl
+use strict;
+use warnings;
+use lib ('lib');
+
+use presque;
+use Plack::Builder;
+use YAML::Syck;
+
+my $conf = LoadFile('conf.yaml');
+my $app = presque->app( config => $conf );
diff --git a/conf.yaml b/conf.yaml
new file mode 100644
index 0000000..df54c1c
--- /dev/null
+++ b/conf.yaml
@@ -0,0 +1,4 @@
+
+redis:
+  host: 127.0.0.1
+  port: 6379
\ No newline at end of file
diff --git a/lib/presque.pm b/lib/presque.pm
index 2116589..5d168d6 100644
--- a/lib/presque.pm
+++ b/lib/presque.pm
@@ -1,8 +1,42 @@
 package presque;
 
-use strict;
-use warnings;
+use Moose;
 our $VERSION = '0.01';
+extends 'Tatsumaki::Application';
+
+use AnyEvent::Redis;
+
+use presque::RestQueueHandler;
+use presque::JobQueueHandler;
+use presque::IndexHandler;
+
+has config => (
+    is => 'rw', isa => 'HashRef', lazy => 1, default => sub {}
+);
+
+has redis => (
+    is => 'rw',
+    isa => 'Object',
+    lazy => 1,
+    default => sub {
+        my $self = shift;
+        my $r = AnyEvent::Redis->new();
+        $r;
+    }
+);
+
+sub app {
+    my ( $class, %args ) = @_;
+    my $self = $class->new(
+        [
+            '/q/(.*)' => 'presque::RestQueueHandler',
+            '/j/(.*)' => 'presque::JobQueueHandler',
+            '/'   => 'presque::IndexHandler',
+        ]
+    );
+    $self->config( delete $args{config} );
+    $self;
+}
 
 1;
 __END__
diff --git a/lib/presque/Backend/Redis.pm b/lib/presque/Backend/Redis.pm
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/lib/presque/Backend/Redis.pm
diff --git a/lib/presque/IndexHandler.pm b/lib/presque/IndexHandler.pm
new file mode 100644
index 0000000..9a8e92e
--- /dev/null
+++ b/lib/presque/IndexHandler.pm
@@ -0,0 +1,14 @@
+package presque::IndexHandler;
+
+use Moose;
+extends 'Tatsumaki::Handler';
+__PACKAGE__->asynchronous(1);
+
+use JSON;
+
+sub get {
+    my $self = shift;
+    # render template
+}
+
+1;
diff --git a/lib/presque/JobQueueHandler.pm b/lib/presque/JobQueueHandler.pm
new file mode 100644
index 0000000..1e6d9e5
--- /dev/null
+++ b/lib/presque/JobQueueHandler.pm
@@ -0,0 +1,13 @@
+package presque::JobQueueHandler;
+
+use Moose;
+extends 'Tatsumaki::Handler';
+__PACKAGE__->asynchronous(1);
+
+use JSON;
+
+sub get {
+    my ($self, $queue_name) = @_;
+}
+
+1;
diff --git a/lib/presque/RestQueueHandler.pm b/lib/presque/RestQueueHandler.pm
new file mode 100644
index 0000000..d953505
--- /dev/null
+++ b/lib/presque/RestQueueHandler.pm
@@ -0,0 +1,81 @@
+package presque::RestQueueHandler;
+
+use Moose;
+extends 'Tatsumaki::Handler';
+__PACKAGE__->asynchronous(1);
+
+use JSON;
+use YAML::Syck;
+
+sub get {
+    my ( $self, $queue_name ) = @_;
+    my $lkey = $queue_name . ':queue';
+    $self->application->redis->lpop(
+        $lkey,
+        sub {
+            my $value = shift;
+            my $qpkey = $queue_name . ':queupolicy';
+            if ($value) {
+                my $val   = $self->application->redis->get(
+                    $value,
+                    sub {
+                        $self->finish(shift);
+                    }
+                );
+            }else{
+                $self->finish(JSON::encode_json({error => "no job"}));
+            }
+        }
+    );
+}
+
+sub post {
+    my ( $self, $queue_name ) = @_;
+
+    my $p = $self->request->content;
+
+    $self->application->redis->incr(
+        $queue_name . ':UUID',
+        sub {
+            my $uuid = shift;
+            my $key  = $queue_name . ':' . $uuid;
+
+            $self->application->redis->set(
+                $key, $p,
+                sub {
+                    my $status_set = shift;
+                    my $lkey = $queue_name . ':queue';
+                    if ($uuid == 1) {
+                        $self->application->redis->sadd(
+                            'QUEUESET',
+                            $lkey,
+                            sub {
+                                my $ckey = 'queuestat:' . $queue_name;
+                                $self->application->redis->set( $ckey, 1 );
+                                $self->_finish_post($lkey, $key, $status_set);
+                            }
+                        );
+                    }else{
+                        $self->_finish_post($lkey, $key, $status_set);
+                    }
+                }
+            );
+        }
+    );
+}
+
+sub _finish_post {
+    my ($self, $lkey, $key, $result) = @_;
+    $self->application->redis->rpush(
+        $lkey, $key,
+        sub {
+            $self->finish($result);
+        }
+    );
+}
+
+sub delete {
+    my ($self, $queue_name) = @_;
+}
+
+1;