use of org.codice.alliance.nsili.common.GIAS.ValidationResults in project alliance by codice.
the class SampleNsiliClient method order.
public PackageElement[] order(DAG dag) throws Exception {
if (orderMgr == null) {
LOGGER.warn("OrderMgr is not initialized, unable to submit order");
return null;
}
LOGGER.info("--------------------------");
LOGGER.info("OrderMgr getting package specifications");
String[] supportedPackageSpecs = orderMgr.get_package_specifications();
if (supportedPackageSpecs != null && supportedPackageSpecs.length > 0) {
for (String supportedPackageSpec : supportedPackageSpecs) {
LOGGER.info(TAB_LOG_MSG, supportedPackageSpec);
}
} else {
LOGGER.warn("Server returned no packaging specifications");
supportedPackageSpecs = new String[0];
}
LOGGER.info("Getting OrderMgr Use Modes");
String[] useModes = orderMgr.get_use_modes();
for (String useMode : useModes) {
LOGGER.info(TAB_LOG_MSG, useMode);
}
LOGGER.info("Order Mgr num of priorities: {} ", orderMgr.get_number_of_priorities());
Product product = getProductFromDag(dag);
String filename = getAttributeFromDag(dag, NsiliConstants.FILENAME) + ".dat";
// Product available
boolean productAvail = orderMgr.is_available(product, useModes[0]);
LOGGER.info("Product available: {}", productAvail);
LOGGER.info("Creating order request...");
Any portAny = orb.create_any();
Any protocolAny = orb.create_any();
protocolAny.insert_string("http");
portAny.insert_long(listenPort);
NameValue portProp = new NameValue("PORT", portAny);
NameValue protocolProp = new NameValue("PROTOCOL", protocolAny);
NameValue[] properties = new NameValue[] { portProp, protocolProp };
OrderContents order = createFileOrder(product, supportedPackageSpecs, filename);
// Validating Order
LOGGER.info("Validating Order...");
ValidationResults validationResults = orderMgr.validate_order(order, properties);
LOGGER.info("Validation Results: ");
LOGGER.info("\tValid : {} \n" + "\tWarning : {} \n" + "\tDetails : {}", validationResults.valid, validationResults.warning, validationResults.details);
OrderRequest orderRequest = orderMgr.order(order, properties);
LOGGER.info("Completing OrderRequest...");
DeliveryManifestHolder deliveryManifestHolder = new DeliveryManifestHolder();
orderRequest.set_user_info(ALLIANCE);
PackageElement[] elements;
try {
orderRequest.complete(deliveryManifestHolder);
if (emailAddress != null) {
order = createEmailOrder(orb, product, supportedPackageSpecs);
// Validating Order
LOGGER.info("Validating Email Order...");
validationResults = orderMgr.validate_order(order, properties);
LOGGER.info("Email Validation Results: ");
LOGGER.info("\tValid : {}\n\tWarning : {}\n\tDetails : {}\n", validationResults.valid, validationResults.warning, validationResults.details);
orderRequest = orderMgr.order(order, properties);
orderRequest.set_user_info(ALLIANCE);
orderRequest.complete(deliveryManifestHolder);
}
DeliveryManifest deliveryManifest = deliveryManifestHolder.value;
LOGGER.info("Completed Order : {}", deliveryManifest.package_name);
elements = deliveryManifest.elements;
if (deliveryManifest.elements != null) {
for (PackageElement element : elements) {
for (String file : element.files) {
LOGGER.info(TAB_LOG_MSG, file);
}
}
}
return elements;
} catch (Exception e) {
LOGGER.error("Error completing order request", NsilCorbaExceptionUtil.getExceptionDetails(e));
return null;
}
}
Aggregations