X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FData.pm;h=2f8a18470a1965c0e154dfad1c5de4cce0c1bbda;hb=83a8a7d6035372ef9d8e78fb46742f7bf2a3a1ca;hp=9f4cf952b1d7ebc64f6759e2708bb5198a185661;hpb=e5f2bda6c8984be0c49a3e058a165286791fef51;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Data.pm b/lib/Gruntmaster/Data.pm index 9f4cf95..2f8a184 100644 --- a/lib/Gruntmaster/Data.pm +++ b/lib/Gruntmaster/Data.pm @@ -9,6 +9,7 @@ use Redis; our $contest; my $redis = Redis->new; +my $pubsub = Redis->new; sub dynsub{ no strict 'refs'; @@ -16,9 +17,13 @@ sub dynsub{ } BEGIN { - for my $cmd (qw/multi exec smembers get hget hset sadd srem incr hmset hsetnx/) { + for my $cmd (qw/multi exec smembers get hget hdel hset sadd srem incr hmset hsetnx/) { dynsub uc $cmd, sub { say "Arguments to \U$cmd: ", join ', ', @_; $redis->$cmd(@_) }; } + + for my $cmd (qw/publish subscribe wait_for_messages/) { + dynsub uc $cmd, sub { say "Arguments to \U$cmd: ", join ', ', @_; $pubsub->$cmd(@_) }; + } } sub cp { defined $contest ? "contest.$contest." : '' } @@ -66,6 +71,11 @@ sub defhash{ defhash problem => qw/name level statement/; defhash contest => qw/start end name owner/; defhash job => qw/date extension filesize private problem result result_text user/; +defhash user => qw/name email town university/; + +sub clean_job (_){ + HDEL cp . "job.$_[0]", qw/result result_text results daemon/ +} our @EXPORT_OK = do { no strict 'refs';