#define MD_AUSREG #include "cliever-md.h" #include "session/SessionFactory.hpp" #include "session/SessionManagerProperties.hpp" #include "session/Transaction.hpp" #include "common/SystemProperties.hpp" #include "session/Session.hpp" #include "session/StatsManager.hpp" #include "se/DomainCheckCommand.hpp" #include "se/DomainCheckResponse.hpp" #include "se/LPE/LPChkCmdExtension.hpp" #include "se/LPE/LPChkRespExtension.hpp" #include "se/LPE/LPCrtCmdExtension.hpp" #include "se/LPE/LPCrtRespExtension.hpp" #include "se/TransferOp.hpp" #include "se/IntPostalInfo.hpp" #include "se/ContactCreateCommand.hpp" #include "se/ContactCreateResponse.hpp" #include "se/DomainCreateCommand.hpp" #include "se/DomainCreateResponse.hpp" #include "se/DomainTransferApproveCommand.hpp" #include "se/DomainTransferRequestCommand.hpp" #include "se/DomainTransferResponse.hpp" #include #include #include #include "mdJSON.hpp"" using namespace std; #define EVENT_SIZE ( sizeof (struct inotify_event) ) #define BUF_LEN ( 1024 * ( EVENT_SIZE + 16 ) ) //char *name1 = "bestever.camera"; // //char *name3 = "pricey.holdings"; // //char *name5 = "greedy.ventures"; // //char *name6 = "shady.ventures"; // //char *name7 = "hemmarhoid.camera"; // //char *name3 = "pricey.holdings"; // char *name1 = "yoda.guru"; char *name2 = "unicycles.bike"; char *name3 = "test-validate.claimsgasix"; char *name4 = "horny.singles"; char *name5 = "atmospheric.lighting"; char *name6 = "mushroomtheory.management"; static TestEnvironment props; static std::string TEST_SE = ""; // static void testExecuteParallelTransactions() throw (EPPException); bool ausRegEPPTK::doNothing(const std::string propertiesFilePath) { // Just verify load bool did=false; try { scenario( 0, propertiesFilePath ); // tkScenario 0 assumed did = true; } catch(std::exception &e) { theseLogs->logN(2,"Scenario %d TK Exception: %s .",tkScenario,e.what()); } return did; } void ausRegEPPTK::doOTEA() { int hours,hoops; string op("newInstance"); scenario(tkScenario,thisConfig->cfg_path); try { Timer::setTime("20140101.010101"); auto_ptr manager(SessionManagerFactory::newInstance(&props)); auto_ptr sess(SessionFactory::newInstance(&props)); op = "startup"; manager->startup(); op = "run (keep-alive)"; manager->run(); sess->open(); for (hours=0;hours < 24;hours++) { // Spawn the keep alive thread. theseLogs->logN(1,"Send Test SEs on or about start OTE Test Hour %d.",hours); for (hoops=0;hoops<7;hoops++) { sess->writeXML(TEST_SE); sess->read(); sleep(857); } } sess->close(); manager->shutdown(); } catch (EPPException& e) { const char *eMsg = e.getMessage().c_str(); const char *opNow = op.c_str(); theseLogs->logN(2,"EPP Exception during OTE A (%s): %s .",opNow,eMsg); throw e; } catch (...) { theseLogs->logN(2,"General Exception during OTE A (%s).",op.c_str()); } } #include "donutsOTEB.h" void ausRegEPPTK::doOTEC() { // This scenario generalizes OTEB so that its operations can be performed // by json scripting. This is a quick and dirty which can be extended in // obvious ways and monitors a directory for new or changed files. bool actionableFileEvent,monitoring=true; int length, i = 0; int fd; int wd; char buffer[BUF_LEN]; fd = inotify_init(); if ( fd < 0 ) { theseLogs->logN(0,"Fatal error, couldn't init inotify."); return; } theseLogs->logN(0,"Monitoring ./json for changes."); wd = inotify_add_watch( fd, "./json", IN_MODIFY | IN_CREATE | IN_DELETE ); length = read( fd, buffer, BUF_LEN ); if ( length < 0 ) { theseLogs->logN(0,"Fatal error, initial inotify read failed."); } while ( i < length && monitoring) { actionableFileEvent = false; struct inotify_event *event = ( struct inotify_event * ) &buffer[ i ]; if ( event->len ) { if ( event->mask & IN_CREATE ) { if ( event->mask & IN_ISDIR ) { theseLogs->logN(1,"The directory %s was created.\n", event->name ); } else { theseLogs->logN(1,"The file %s was created.\n", event->name ); actionableFileEvent = true; } } else if ( event->mask & IN_DELETE ) { if ( event->mask & IN_ISDIR ) { theseLogs->logN(1,"The directory %s was deleted.\n", event->name ); } else { printf( "The file %s was deleted.\n", event->name ); } } else if ( event->mask & IN_MODIFY ) { if ( event->mask & IN_ISDIR ) { theseLogs->logN(1, "The directory %s was modified.\n", event->name ); } else { theseLogs->logN(1, "The file %s was modified.\n", event->name ); actionableFileEvent = true; } } } i += EVENT_SIZE + event->len; if (actionableFileEvent) { mdJSON scriptor(event->name); if (scriptor.parse()) { if (registryXOTE()) { if (didDie) { monitoring = false; theseLogs->logN(1, "Run of %s fatal error. ./json monitoring stops.\n", event->name ); theseLogs->logN(0, "Restart process to resume operations." ); } else { theseLogs->logN(1, "Run of %s has errors ./json monitoring continues.\n", event->name ); } } else theseLogs->logN(1, " %s completed OK. ./json monitoring continues. \n", event->name ); } else { theseLogs->logN(1, "Parse of %s failed. ,/json monitoring continues.\n", event->name ); } } else sleep(1); } ( void ) inotify_rm_watch( fd, wd ); ( void ) close( fd ); } void ausRegEPPTK::doOTEP() { int hours,hoops; string op("newInstance"); scenario(thisConfig->tkScenario,thisConfig->cfg_path); try { Timer::setTime("20140101.010101"); auto_ptr manager(SessionManagerFactory::newInstance(&props)); auto_ptr sess(SessionFactory::newInstance(&props)); op = "startup"; manager->startup(); op = "run (keep-alive)"; manager->run(); sess->open(); for (hours=0;hours < 24;hours++) { // Spawn the keep alive thread. theseLogs->logN(1,"AC Production Hour %d.",hours); // if thisEPPServer(mdStdDevIdx).vendor == "Donuts" for (hoops=0;hoops<7;hoops++) { sess->writeXML(TEST_SE); sess->read(); sleep(857); } } sess->close(); manager->shutdown(); } catch (EPPException& e) { const char *eMsg = e.getMessage().c_str(); const char *opNow = op.c_str(); theseLogs->logN(2,"EPP Exception in Production (%s): %s .",opNow,eMsg); throw e; } catch (...) { theseLogs->logN(2,"General Exception Production (%s).",op.c_str()); } }