X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FData.pm;h=9504cf849b7220c6e658fc16c33a283cc5f2fd57;hb=6eff0ac56cb1c41c771153c0a03a74a7fd4b2100;hp=544a6d060613d816a305c5e3ea6700a351523116;hpb=3da9c3c228106c819530a0b8e4c646981e6f71c9;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Data.pm b/lib/Gruntmaster/Data.pm index 544a6d0..9504cf8 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'; @@ -19,6 +20,10 @@ BEGIN { for my $cmd (qw/multi exec smembers get hget 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." : '' } @@ -59,12 +64,14 @@ sub defhash{ dynsub "push_$name", sub { my $nr = INCR cp . $name; HMSET cp . "$name.$nr", @_; + $nr }; } defhash problem => qw/name level statement/; defhash contest => qw/start end name owner/; -defhash job => qw/date file name private problem result result_text user/; +defhash job => qw/date extension filesize private problem result result_text user/; +defhash user => qw/name email town university/; our @EXPORT_OK = do { no strict 'refs';