use of org.codice.alliance.nsili.common.GIAS.OrderRequest in project alliance by codice.
the class OrderMgrImpl method order.
@Override
public OrderRequest order(OrderContents order, NameValue[] properties) throws ProcessingFault, InvalidInputParameter, SystemFault {
OrderRequestImpl orderRequest = new OrderRequestImpl();
try {
_poa().activate_object_with_id("order".getBytes(Charset.forName(ENCODING)), orderRequest);
} catch (ServantAlreadyActive | ObjectAlreadyActive | WrongPolicy e) {
LOGGER.warn("Order : Unable to activate orderRequest object.", e);
}
org.omg.CORBA.Object obj = _poa().create_reference_with_id("order".getBytes(Charset.forName(ENCODING)), OrderRequestHelper.id());
OrderRequest queryRequest = OrderRequestHelper.narrow(obj);
return queryRequest;
}
use of org.codice.alliance.nsili.common.GIAS.OrderRequest in project alliance by codice.
the class OrderMgrImpl method order.
@Override
public OrderRequest order(OrderContents order, NameValue[] properties) throws ProcessingFault, InvalidInputParameter, SystemFault {
String protocol = "http";
int port = 80;
for (NameValue prop : properties) {
if (prop.aname.equals(NsiliConstants.PROP_PROTOCOL)) {
protocol = DAGConverter.getString(prop.value);
} else if (prop.aname.equals(NsiliConstants.PROP_PORT)) {
Integer portInteger = DAGConverter.getInteger(prop.value);
if (portInteger != null) {
port = portInteger;
}
}
}
OrderRequestImpl orderRequestImpl = new OrderRequestImpl(order, protocol, port, getAccessManager(), catalogFramework, emailConfiguration);
String id = UUID.randomUUID().toString();
try {
_poa().activate_object_with_id(id.getBytes(Charset.forName(NsiliEndpoint.ENCODING)), orderRequestImpl);
} catch (ServantAlreadyActive | ObjectAlreadyActive | WrongPolicy e) {
LOGGER.debug("order : Unable to activate orderRequest object.", e);
}
org.omg.CORBA.Object obj = _poa().create_reference_with_id(id.getBytes(Charset.forName(NsiliEndpoint.ENCODING)), OrderRequestHelper.id());
OrderRequest orderRequest = OrderRequestHelper.narrow(obj);
return orderRequest;
}
use of org.codice.alliance.nsili.common.GIAS.OrderRequest 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