...
Rationale and design issues
Usage guide
Interface identityThis is a SOAP web service interface named OpcOrderTrackingService. The main purpose of this web service is to track the status of a purchase order with a given order id.
ResourcesOrderDetails getOrderDetails(String orderId) 
...
- Authorization. Only a signed in user is authorized to call this operation. A customer user can only get information about orders he created. A sales representative user can get information about any order.
- Concurrent access. There isn't any limitation on the number of concurrent accesses of this interface. The service is implemented by using EJBs and concurrent calls to it are managed by the EJB container.
Data types and constants- Type OrderDetails. This data structure contains the retrieved PurchaseOrder along with its status. Attributes:
...
The PurchaseOrder type is described in the  OpcPurchaseOrderService interface documentation.
Error handlingThe exceptions raised by this interface are:
- OrderNotFoundException. The service throws this exception if no purchase order with the given order id was found, or the orderId was null or ill-formed.
- RemoteException. The caller receives a RemoteException when there is a communication problem with the service provider implementing this interface.
VariabilityN/A.
Quality attribute characteristics- Scalability: see discussion in Deployment View - Rationale.
- Performance: the operation shall return the results in less than 1 second.
Rationale and design issues- Java-to-WSDL approach for design of interface
Since both the consumer website and the order processing center reside in the same enterprise we prefer the ease of development provided by JavaToWsdl compiler over stability of a manually-maintained WSDL description. However, this may result in rewriting the clients of this service every time we make a change to this interface.
Usage guideContext ic = new InitialContext();
OpcOrderTrackingService opcOrderTrackingSvc =
     (OpcOrderTrackingService) ic.lookup("java:comp/env/service/OpcOrderTrackingService");
OrderTrackingIntf port = (OrderTrackingIntf) opcOrderTrackingSvc.getOrderTrackingIntfPort();
OrderDetails orderDetails = port.getOrderDetails(orderId);