use of org.codice.alliance.nsili.common.UCO.NameValue 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;
}
}
use of org.codice.alliance.nsili.common.UCO.NameValue in project alliance by codice.
the class SampleNsiliClient method getRelatedFiles.
public String[] getRelatedFiles(Product product) throws Exception {
if (productMgr != null) {
LOGGER.info("Sending Get Related Files Request...");
final FileLocation fileLocation = new FileLocation("user", "pass", "localhost", "/nsili/file", "");
Any portAny = orb.create_any();
portAny.insert_string(String.valueOf(listenPort));
NameValue portProp = new NameValue("PORT", portAny);
NameValue[] properties = new NameValue[] { portProp };
Product[] products = { product };
GetRelatedFilesRequest relatedFilesRequest = productMgr.get_related_files(products, fileLocation, NsiliConstants.THUMBNAIL_TYPE, properties);
relatedFilesRequest.set_user_info(ALLIANCE);
NameListHolder locations = new NameListHolder();
relatedFilesRequest.complete(locations);
String[] locationList = locations.value;
if (locationList.length > 0) {
LOGGER.info("Location List : ");
for (String location : locationList) {
LOGGER.info("\t Stored File: {}", location);
}
} else {
LOGGER.info("No locations returned from Get Related Files Request");
}
return locationList;
} else {
LOGGER.warn("ProductMgr is not initialized, unable to get related files");
return null;
}
}
use of org.codice.alliance.nsili.common.UCO.NameValue in project alliance by codice.
the class SampleNsiliClient method getParameters.
public DAG getParameters(Product product) throws InvalidInputParameter, SystemFault, ProcessingFault {
if (productMgr != null) {
LOGGER.info("Sending Get Parameters Request...");
// CORE, ALL, ORDER
String[] desiredParameters = new String[] { "CORE", "ALL", "ORDER" };
NameValue[] properties = new NameValue[0];
GetParametersRequest getParametersRequest = productMgr.get_parameters(product, desiredParameters, properties);
getParametersRequest.set_user_info(ALLIANCE);
DAGHolder dagHolder = new DAGHolder();
getParametersRequest.complete(dagHolder);
LOGGER.info("Resulting Parameters From Server :");
DAG dag = dagHolder.value;
printDagAttributes(dag);
return dag;
} else {
LOGGER.warn("ProductMgr is not initialized, unable to get parameters");
}
return null;
}
Aggregations