// Berkeley Open Infrastructure for Network Computing // http://boinc.berkeley.edu // Copyright (C) 2005 University of California // // This is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; // either version 2.1 of the License, or (at your option) any later version. // // This software is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. // See the GNU Lesser General Public License for more details. // // To view the GNU Lesser General Public License visit // http://www.gnu.org/copyleft/lesser.html // or write to the Free Software Foundation, Inc., // 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // trickle_handler - framework for trickle-up message handler // // -variety variety // [-d debug_level] // [-one_pass] // make one pass through table, then exit // [-asynch] // fork, run in separate process // // This program must be linked with an app-specific function: // // int handle_trickle(MSG_FROM_HOST&) // handle a trickle message // // return nonzero on error using namespace std; #include "config.h" #include #include "boinc_db.h" #include "util.h" #include "sched_config.h" #include "sched_util.h" #include "sched_msgs.h" SCHED_CONFIG config; char variety[256]; extern int handle_trickle(MSG_FROM_HOST&); // The following is an example; // replace it with your own function // int handle_trickle(MSG_FROM_HOST& mfh) { int retval; printf( "got trickle-up \n%s\n\n", mfh.xml ); DB_MSG_TO_HOST mth; mth.clear(); mth.create_time = time(0); mth.hostid = mfh.hostid; strcpy(mth.variety, mfh.variety); mth.handled = false; sprintf(mth.xml, "\n" "%s" "\n", mfh.xml ); retval = mth.insert(); if (retval) { printf("insert failed %d\n", retval); } return 0; } // make one pass through trickle_ups with handled == 0 // return true if there were any // bool do_trickle_scan(APP& app) { DB_MSG_FROM_HOST mfh; char buf[256]; bool found=false; int retval; sprintf(buf, "where variety='%s' and handled=0", variety); while (!mfh.enumerate(buf)) { retval = handle_trickle(mfh); if (!retval) { mfh.handled = true; mfh.update(); } found = true; } return found; } int main_loop(bool one_pass) { int retval; DB_APP app; bool did_something; char buf[256]; retval = boinc_db.open(config.db_name, config.db_host, config.db_user, config.db_passwd); if (retval) { log_messages.printf(SCHED_MSG_LOG::CRITICAL, "boinc_db.open failed: %d\n", retval); exit(1); } while (1) { check_stop_daemons(); did_something = do_trickle_scan(app); if (one_pass) break; if (!did_something) { sleep(5); } } return 0; } int main(int argc, char** argv) { int i, retval; bool asynch = false, one_pass = false; check_stop_daemons(); for (i=1; i