JavaScript kifejlesztése elemzések blokkolásához feltételek alapján

Amikor egy felhasználó elemzést próbál futtatni, az Oracle Analytics meghívja a validateAnalysisCriteria függvényt. A validateAnalysisCriteria testreszabható, hogy ellenőrizzen és blokkoljon lekérdezéseket a saját specifikus feltételeink szerint. Ha a függvény a true értéket adja vissza, a lekérdezés fut. Ha a függvény a false értéket adja vissza, vagy üzenetet jelenít meg, a lekérdezés blokkolva van.

Például a következő egy mintakód egy myblocking.js nevű JavaScript-programhoz.

// This is a blocking function. It ensures that users select what 
// the designer wants them to.
function validateAnalysisCriteria(analysisXml)
{
   // Create the helper object
   var tValidator = new CriteriaValidator(analysisXml);
   // Validation Logic
   if (tValidator.getSubjectArea() != "Sample Sales")
      return "Try Sample Sales?";
   if (!tValidator.dependentColumnExists("Markets","Region","Markets","District"))
   {
      // If validation script notifies user, then return false
      alert("Region and District are well suited, do you think?");
      return false;
   }
   if (!tValidator.dependentColumnExists("Sales Measures","","Periods","Year"))
   return "You selected a measure so pick Year!";
   if (!tValidator.filterExists("Sales Measures","Dollars"))
   return "Maybe filter on Dollars?";
   if (!tValidator.dependentFilterExists("Markets","Market","Markets"))
   return "Since you are showing specific Markets, filter the markets.";
   var n = tValidator.filterCount("Markets","Region");
   if ((n <= 0) || (n > 3))
      return "Select 3 or fewer specific Regions";
   return true;
}

Ha a függvény által visszaadott érték nem false, a program a feltételt érvényesnek tekinti, és az elemzés fut. A függvény használatos feltételek ellenőrzéséhez is a műveletek előnézetéhez és mentéséhez.