/[cvs]/joko/TestArea/perl/runtime/POE/db/dbiagent.pl
ViewVC logotype

Contents of /joko/TestArea/perl/runtime/POE/db/dbiagent.pl

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (show annotations)
Sun May 11 21:48:50 2003 UTC (21 years, 4 months ago) by joko
Branch: MAIN
CVS Tags: HEAD
File MIME type: text/plain
initial commit

1 #!/usr/bin/perl
2
3 use warnings;
4 use strict;
5
6 # ---------------------------------------------------------------
7 # just using POE itself and the DBIAgent-component as a query-agent (QA)
8 use POE qw( Component::DBIAgent );
9 # for debugging ...
10 use Carp;
11 use Data::Dumper;
12
13
14 # ---------------------------------------------------------------
15 sub make_queries {
16 ## makes a hash from sql-query-strings
17 ## which will be passed to the query-agent later
18 my $queries = {
19 read_message => 'SELECT * FROM pdmsg WHERE state IS NULL',
20 update_one_account => 'update hits_due set hits = hits + ? where acctid = ?',
21 };
22 return $queries;
23 }
24
25
26 # ---------------------------------------------------------------
27 sub got_row {
28 ## This state gets called once for every row returned
29 ## from the query read_hits_due, and then once
30 ## with $_[ARG0] containing the string 'EOF'.
31
32 #carp("============= got result", "\n");
33
34 my ( $kernel, $self, $heap, $row ) = @_[ KERNEL, OBJECT, HEAP, ARG0 ];
35
36 if ( $row ne 'EOF' ) {
37 # PROCESS A ROW
38 print "------------------ got row", "\n";
39 print Dumper($row);
40 } else {
41 # NO MORE ROWS
42 print "--- no more rows", "\n";
43 # let the kernel run for two/three timeslices ...
44 #$kernel->run_one_timeslice();
45 #$kernel->run_one_timeslice();
46 #$kernel->run_one_timeslice();
47 # ... before stopping it by sending an "IDLE"-signal
48 # does it do with "IDLE"?
49 #$kernel->signal($kernel, "IDLE");
50 # do we need to TERM?
51 #$kernel->signal($kernel, "TERM");
52 }
53 }
54
55
56 # ---------------------------------------------------------------
57 sub got_error {
58 my ( $kernel, $heap, $errmsg ) = @_[ KERNEL, HEAP, ARG0 ];
59 print "$0 got error:", "\n", $errmsg, "\n";
60 $kernel->signal($kernel, "TERM");
61 }
62
63
64 # ---------------------------------------------------------------
65 sub _start {
66 my ( $kernel, $session, $heap ) = @_[ KERNEL, HEAP ];
67
68 # setting up the query-agent
69 $heap->{helper} = POE::Component::DBIAgent->new(
70 DSN => [ 'dbi:mysql:topscores:host=192.168.10.51',
71 "root",
72 ""
73 ],
74 Count => 1, # how many agents to start
75 Queries => make_queries(), # the "queries"-hash
76 Debug => 1, # turn debugging on/off
77 );
78
79 # reference to session which will recieve results
80 #my $sess = $kernel->get_active_session();
81
82 # start query-agent
83 $heap->{helper}->setErrorHandler(
84 $session => 'got_error'
85 );
86 $heap->{helper}->query(
87 read_message # the named query to execute
88 => $session => 'got_row' # the session and state to send results to
89 # and any parameters would go here.
90 );
91
92 }
93
94 # ---------------------------------------------------------------
95 sub _stop {
96 my ( $kernel, $heap ) = @_[ KERNEL, HEAP ];
97 print "$0 stopped", "\n";
98 }
99
100
101 # ---------------------------------------------------------------
102 # the handlers for starting, stopping
103 # and getting valid or invalid responses (errors)
104 my @handlers = qw(
105 _start
106 _stop
107 got_row
108 got_error
109 );
110 # the main session for the query-agent
111 POE::Session->create(
112 package_states => [ main => \@handlers ],
113 );
114
115
116 # ---------------------------------------------------------------
117 # start the kernel
118 $poe_kernel->run();
119 exit;

MailToCvsAdmin">MailToCvsAdmin
ViewVC Help
Powered by ViewVC 1.1.26 RSS 2.0 feed