Search in sources :

Example 1 with OrderRequest

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;
}
Also used : WrongPolicy(org.omg.PortableServer.POAPackage.WrongPolicy) ObjectAlreadyActive(org.omg.PortableServer.POAPackage.ObjectAlreadyActive) OrderRequest(org.codice.alliance.nsili.common.GIAS.OrderRequest) OrderRequestImpl(org.codice.alliance.nsili.mockserver.impl.requests.OrderRequestImpl) ServantAlreadyActive(org.omg.PortableServer.POAPackage.ServantAlreadyActive)

Example 2 with OrderRequest

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;
}
Also used : ObjectAlreadyActive(org.omg.PortableServer.POAPackage.ObjectAlreadyActive) OrderRequest(org.codice.alliance.nsili.common.GIAS.OrderRequest) NsiliEndpoint(org.codice.alliance.nsili.endpoint.NsiliEndpoint) NameValue(org.codice.alliance.nsili.common.UCO.NameValue) WrongPolicy(org.omg.PortableServer.POAPackage.WrongPolicy) OrderRequestImpl(org.codice.alliance.nsili.endpoint.requests.OrderRequestImpl) ServantAlreadyActive(org.omg.PortableServer.POAPackage.ServantAlreadyActive)

Example 3 with 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;
    }
}
Also used : OrderRequest(org.codice.alliance.nsili.common.GIAS.OrderRequest) DeliveryManifest(org.codice.alliance.nsili.common.GIAS.DeliveryManifest) Product(org.codice.alliance.nsili.common.UID.Product) Any(org.omg.CORBA.Any) KeyManagementException(java.security.KeyManagementException) NoSuchAlgorithmException(java.security.NoSuchAlgorithmException) IOException(java.io.IOException) URISyntaxException(java.net.URISyntaxException) MalformedURLException(java.net.MalformedURLException) CertificateException(java.security.cert.CertificateException) NameValue(org.codice.alliance.nsili.common.UCO.NameValue) ValidationResults(org.codice.alliance.nsili.common.GIAS.ValidationResults) OrderContents(org.codice.alliance.nsili.common.GIAS.OrderContents) DeliveryManifestHolder(org.codice.alliance.nsili.common.GIAS.DeliveryManifestHolder) PackageElement(org.codice.alliance.nsili.common.GIAS.PackageElement)

Aggregations

OrderRequest (org.codice.alliance.nsili.common.GIAS.OrderRequest)3 NameValue (org.codice.alliance.nsili.common.UCO.NameValue)2 ObjectAlreadyActive (org.omg.PortableServer.POAPackage.ObjectAlreadyActive)2 ServantAlreadyActive (org.omg.PortableServer.POAPackage.ServantAlreadyActive)2 WrongPolicy (org.omg.PortableServer.POAPackage.WrongPolicy)2 IOException (java.io.IOException)1 MalformedURLException (java.net.MalformedURLException)1 URISyntaxException (java.net.URISyntaxException)1 KeyManagementException (java.security.KeyManagementException)1 NoSuchAlgorithmException (java.security.NoSuchAlgorithmException)1 CertificateException (java.security.cert.CertificateException)1 DeliveryManifest (org.codice.alliance.nsili.common.GIAS.DeliveryManifest)1 DeliveryManifestHolder (org.codice.alliance.nsili.common.GIAS.DeliveryManifestHolder)1 OrderContents (org.codice.alliance.nsili.common.GIAS.OrderContents)1 PackageElement (org.codice.alliance.nsili.common.GIAS.PackageElement)1 ValidationResults (org.codice.alliance.nsili.common.GIAS.ValidationResults)1 Product (org.codice.alliance.nsili.common.UID.Product)1 NsiliEndpoint (org.codice.alliance.nsili.endpoint.NsiliEndpoint)1 OrderRequestImpl (org.codice.alliance.nsili.endpoint.requests.OrderRequestImpl)1 OrderRequestImpl (org.codice.alliance.nsili.mockserver.impl.requests.OrderRequestImpl)1