Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 1 | .. _appc_client_library: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 2 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 3 | ================================================== |
| 4 | Application Controller (APPC) Client Library Guide |
| 5 | ================================================== |
| 6 | |
| 7 | |
| 8 | Revision History |
Scott Seabolt | f782483 | 2017-10-10 11:27:11 -0400 | [diff] [blame^] | 9 | ================ |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 10 | |
| 11 | +--------------+------------+---------------+--------------------------------------------------+ |
| 12 | | Date | Revision | Author | Changes | |
| 13 | +--------------+------------+---------------+--------------------------------------------------+ |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 14 | | 2017-08-22 | 1.0.0 | Paul Miller | First draft | |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 15 | +--------------+------------+---------------+--------------------------------------------------+ |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 16 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 17 | Introduction |
| 18 | ============ |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 19 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 20 | Target Audience |
| 21 | --------------- |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 22 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 23 | This document is for an advanced technical audience, which includes engineers and technicians. Document revisions occur with the release of new software versions. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 24 | |
| 25 | Related Documentation |
| 26 | --------------------- |
| 27 | |
Scott Seabolt | f782483 | 2017-10-10 11:27:11 -0400 | [diff] [blame^] | 28 | For additional information, see |
| 29 | |
| 30 | :ref:`appc_api_guide` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 31 | |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 32 | |
| 33 | Client Library Background |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 34 | ========================= |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 35 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 36 | This guide discusses the Application Controller (APPC) Client Library and how to use it. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 37 | |
| 38 | About the Client Library |
| 39 | ------------------------ |
| 40 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 41 | The APPC client library provides consumers of APPC capabilities with a strongly-typed Java interface and encapsulates the actual interaction with the APPC component over an asynchronous messaging channel such as UEB. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 42 | |
| 43 | Consumer Logic |
| 44 | -------------- |
| 45 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 46 | The client application that consumes APPC’s capability for VNF lifecycle management (the APPC client library) can be implemented against the lightweight and strongly-typed Java API exposed by the APPC client library. The library does not try to impose architectural constraints upon clients, but instead provides support for different options and styles of API. It is the responsibility of the client application to select the most suitable paradigm to use; for example, a client may choose to use blocking calls as opposed to asynchronous notifications. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 47 | |
| 48 | VNF Lifecycle Management API |
| 49 | ---------------------------- |
| 50 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 51 | The API represents a relatively thin layer that consists mainly of business interfaces with strongly-typed APIs and a data object model created for the convenience of the consumer application. The original YANG schema used by the APPC component and the underlying MD-SAL layer on the server-side generates these artifacts. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 52 | |
| 53 | APP-C Client Library Flow |
| 54 | ------------------------- |
| 55 | |
| 56 | |image0| |
| 57 | |
Scott Seabolt | f782483 | 2017-10-10 11:27:11 -0400 | [diff] [blame^] | 58 | Asynchronous Flow |
| 59 | ^^^^^^^^^^^^^^^^^ |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 60 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 61 | - The APPC Client Library is called using an asynchronous API using a full command object, which is mapped to a JSON representation. |
| 62 | - The APPC client calls the UEB client and sends the JSON command to a configured topic. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 63 | - The APPC client pulls response messages from the configured topic. |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 64 | - On receiving the response for the command, the APPC client runs the relevant callback method of the consumer ResponseHandler. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 65 | |
Scott Seabolt | f782483 | 2017-10-10 11:27:11 -0400 | [diff] [blame^] | 66 | Synchronous Flow |
| 67 | ^^^^^^^^^^^^^^^^ |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 68 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 69 | - The APPC Client Library is called using a synchronous API using a full command object, which is mapped to a JSON representation. |
| 70 | - The APPC client calls the UEB client and sends the JSON command to a configured topic. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 71 | - The APPC client pulls response messages from the configured topic. |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 72 | - On receiving the **final** response for the command, the APPC client returns the response object with a final status. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 73 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 74 | Client Library Usage |
| 75 | ==================== |
| 76 | |
| 77 | Jar Files |
| 78 | --------- |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 79 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 80 | The Java application that runs the APPC client kit uses the following jar files: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 81 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 82 | - com.att.appc.client.client-kit |
| 83 | - com.att.appc.client.client-lib |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 84 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 85 | The client library JAR files are located in the repository under ``com\\att\\appc\\client``. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 86 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 87 | Initialization |
Scott Seabolt | 2406a97 | 2017-09-13 17:31:44 -0400 | [diff] [blame] | 88 | -------------- |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 89 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 90 | Initialize the client by calling the following method: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 91 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 92 | ``AppcClientServiceFactoryProvider.getFactory(AppcLifeCycleManagerServiceFactory.class).createLifeCycleManagerStateful()`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 93 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 94 | Specify the following configuration properties as method parameters: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 95 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 96 | - "topic.read" |
| 97 | - "topic.read.timeout" |
| 98 | - "topic.write" |
| 99 | - "client.key" |
| 100 | - "client.secret" |
| 101 | - "client.name" |
| 102 | - "client.name.id" |
| 103 | - "poolMembers" |
| 104 | - “client.response.timeout” |
| 105 | - “client.graceful.shutdown.timeout” |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 106 | |
| 107 | Shutdown |
Scott Seabolt | 2406a97 | 2017-09-13 17:31:44 -0400 | [diff] [blame] | 108 | -------- |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 109 | |
| 110 | Shutdown the client by calling the following method: |
| 111 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 112 | ``void shutdownLifeCycleManager(boolean isForceShutdown)`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 113 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 114 | If the ``isForceShutdown`` flag is set to false, the client shuts down as soon as all responses for pending requests are received, or upon configurable timeout. (``client.graceful.shutdown.timeout``). |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 115 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 116 | If the ``isForceShutdown`` flag is set to true, the client shuts down immediately. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 117 | |
| 118 | Invoking LCM Commands |
Scott Seabolt | 2406a97 | 2017-09-13 17:31:44 -0400 | [diff] [blame] | 119 | --------------------- |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 120 | |
| 121 | Invoke the LCM commands by: |
| 122 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 123 | - Creating input objects, such as AuditInput, LiveUpgradeInput, with relevant command information. |
| 124 | - Executing commands asynchronously, for example: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 125 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 126 | ``void liveUpgrade(LiveUpgradeInput liveUpgradeInput, ResponseHandler<LiveUpgradeOutput> listener) throws AppcClientException;)`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 127 | |
| 128 | In this case, client should implement the ResponseHandler<T> interface. |
| 129 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 130 | - Executing commands synchronously, for example: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 131 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 132 | ``LiveUpgradeOutput liveUpgrade(LiveUpgradeInput liveUpgradeInput) throws AppcClientException;)`` |
| 133 | |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 134 | |
| 135 | Client API |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 136 | ========== |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 137 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 138 | After initializing the client, a returned Object of type LifeCycleManagerStateful defines all the Life Cycle Management APIs |
| 139 | supported by APPC. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 140 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 141 | The interface contains two definitions for each RPC: one for Asynchronous call mode, and one for Synchronous. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 142 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 143 | In Asynchronous mode, client consumer should provide a callback function of type: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 144 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 145 | ``ResponseHandler<RPC-NAMEOutput>`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 146 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 147 | where ``RPC-NAME`` is the command name, such as Audit or Snapshot. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 148 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 149 | There may be multiple calls to the ResponseHandler for each response returned by APPC. For example, first 100 ‘accept’ is returned, then 400 ‘success’. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 150 | |
| 151 | LifeCycleManagerStateful Interface |
| 152 | ---------------------------------- |
| 153 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 154 | Generated from the APPC Yang model, this interface defines the services and request/response requirements for the ECOMP APPC component. For example, for LCM Command Audit, the following is defined: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 155 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 156 | ``@RPC(name="audit", outputType=AuditOutput.class)`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 157 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 158 | ``AuditOutput audit(AuditInput auditInput) throws AppcClientException;`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 159 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 160 | For a Synchronous call to Audit, the consumer thread is blocked until a response is received or a timeout exception is thrown. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 161 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 162 | ``@RPC(name="audit", outputType=AuditOutput.class)`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 163 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 164 | ``void audit(AuditInput auditInput, ResponseHandler<AuditOutput> listener) throws AppcClientException;`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 165 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 166 | For an Asynchronous call to Audit, a callback should be provided so that when a response is received the listener is called. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 167 | |
| 168 | API documentation |
| 169 | ----------------- |
| 170 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 171 | The API documentation is also available as a swagger page generated from files at /client-kit/target/resources. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 172 | |
| 173 | appc-provider-lcm |
| 174 | ----------------- |
| 175 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 176 | This defines the services and request/response requirements for the APPC component. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 177 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 178 | Methods |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 179 | -------- |
| 180 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 181 | The methods should match the actions described in the LCM API Guide. For each method: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 182 | |
| 183 | **Consumes** |
| 184 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 185 | This API call consumes the following media types using the**Content-Type** request header: |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 186 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 187 | - ``application/json`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 188 | |
| 189 | **Request body** |
| 190 | |
| 191 | The request body is the action name followed by Input (e.g., AuditInput) |
| 192 | |
| 193 | **Return type** |
| 194 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 195 | The return type is the action name followed by Output (e.g., OutputInput) |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 196 | |
| 197 | **Produces** |
| 198 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 199 | This API call produces the following media types according to the **Accept** request header; the **Content-Type** response header conveys the media type. |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 200 | |
Scott Seabolt | d51cafc | 2017-09-20 10:33:30 -0400 | [diff] [blame] | 201 | - ``application/json`` |
Scott Seabolt | 59153e9 | 2017-09-08 15:08:33 -0400 | [diff] [blame] | 202 | |
| 203 | **Responses** |
| 204 | |
| 205 | 200 Successful operation |
| 206 | |
| 207 | 401 Unauthorized |
| 208 | |
| 209 | 500 Internal server error |
| 210 | |
| 211 | .. |image0| image:: image2.png |
| 212 | :width: 5.60495in |
| 213 | :height: 4.55272in |