Using the Inbound Adapter for Cloud Storage
Within a production, you can include custom business services that use the inbound cloud adapter to retrieve data from cloud storage. To do so, create one or more business service classes as described here. Then add them to your production and configure them.
Overall Behavior of the Adapter
The cloud inbound adapter, EnsLib.CloudStorage.InboundAdapterOpens in a new tab, provides settings that you can use to specify the location of the cloud storage to examine, as well as settings to authenticate to the service provider. When included in a business service, the adapter periodically polls for available resources. Then at each polling interval:
- 
If the adapter finds input from its configured data source, it constructs an input object to hold the data, and it calls the internal ProcessInput() method of the business service, passing the object to it. The input object depends upon the adapter. 
- 
The internal ProcessInput() method of the business service receives the input object. It then performs basic production tasks such as maintaining internal information as needed by all business services. You do not customize or override this method, which your business service class inherits. 
- 
The ProcessInput() method then calls your custom OnProcessInput() method, passing the input object. The requirements for this method are described in Implementing the OnProcessInput() Method. 
- 
Your custom OnProcessInput() method examines the input object and sends it to other hosts in the production (or creates and sends new messages based on the input object). 
Creating a Business Service
To use the cloud inbound adapter, create a business service class as follows:
- 
Your business service class should extend Ens.BusinessServiceOpens in a new tab. 
- 
In your class, the ADAPTER parameter should equal EnsLib.CloudStorage.InboundAdapterOpens in a new tab. 
- 
Your class should implement the OnProcessInput() method, as described in Implementing the OnProcessInput() Method. 
- 
For other options and general information, see Defining a Business Service Class. 
Implementing the OnProcessInput() Method
Within your business service class, your OnProcessInput() method should have the following signature:
Method OnProcessInput(pInput As EnsLib.CloudStorage.InboundInput, 
                      Output pOutput As %RegisteredObject) As %Status {
}
Where:
- 
pInput is the input object created by the adapter, using data retrieved from cloud storage. 
- 
pOutput is the generic output argument required in the method signature. You can use a more specific message class in the method signature. 
The OnProcessInput() method should do the following:
- 
Examine the input object (pInput) and decide how to use it. The Content property of this object is a stream that contains the data retrieved from the cloud storage. 
- 
Create an instance of the request message, which will be the message that your business service sends. For information on creating message classes, see Defining Messages. 
- 
For the request message, set its properties as appropriate, using values in the input. 
- 
Call a suitable method of the business service to send the request to some destination within the production. Specifically, call SendRequestSync(), SendRequestAsync(), or (less common) SendDeferredResponse(). For details, see Sending Request Messages. Each of these methods returns a status (specifically, an instance of %StatusOpens in a new tab). 
- 
Make sure that you set the output argument (pOutput). Typically you set this equal to the response message that you have received. This step is required. 
- 
Return an appropriate status. This step is required. 
Properties of the Input Object
The input object is an instance of EnsLib.CloudStorage.InboundInputOpens in a new tab, which has the following properties:
- 
Name is the name of cloud storage blob. 
- 
Meta contains the metadata associated with the cloud storage blob. 
- 
Content is a stream that contains the data from cloud storage. 
Your OnProcessInput() method should examine these properties and use them as needed for your business case.
Reprocessing a Blob
Normally, if a blob has been processed, it will be ignored by future processing. If you need to force the production to reprocess a blob, you can remove the global node that tells the system the blob has been processed:
^Ens.AppData(..BusinessHost.%ConfigName, BucketName, BlobName)
For example, suppose that the business host MyProduction.MyService processes blobs and suppose that its configuration name is BucketProcessor. Also suppose that this business host has processed a blob named mysample/data1 in a bucket named Bucket1. To force this business host to reprocess this blob, use the ObjectScript shell, go to the namespace where the production is running, and execute the following command:
 kill ^Ens.AppData("BucketProcessor", "Bucket1", "mysample/data1")