Creating APIs


To publish your APIs to EnOS and make them available for authorized consumers, you need to define your own APIs in the API Management page first.


This section shows how to create an API in APIM.

Before You Start

Ensure that you have an EnOS account and the permissions to create APIs in the EnOS Management Console. For more information, see Policies, Roles, and Permissions.

Procedure

Creating API Groups

  1. Log in to the EnOS Management Console and select API Management > My APIs.

  2. Click New Group and enter the details for the following fields.

    • Service Instance: EnOS Partner Shared Instance

      Note

      Two types of service instances are available: EnOS Platform Exclusive Instance and EnOS Partner Shared Instance. The former is an exclusive resource, available for EnOS OU users. The latter is a shared resource which is shared among the third-party OUs, and is available for both EnOS OU users and third-party OU users. The root path of the shared instance is /apim-instance-partner.

    • Name: Upper and lower case letters, numbers, hyphen (-) are supported and its length is limited to 32 characters

    • Path: Limited to 255 characters.

    • Description: Limited to 140 characters


  3. Click Save to create the API group.

Basic Information

  1. Click the API group you created and then click Add API in the Group Overview page.

  2. In the API Basic Information page, enter the details for the following fields and click Next.

    • API Name

    • API Type

      • EnOS API: the internal API that is available to the customers, e.g. EnOS APIs.

      • APIs developed by EnOS partners: the internal or external APIs in the domain, such as weather service APIs.

    • Authentication Mode

    • API Description

Back-end Service

Configure the back-end service for the API. Use the Get Device API as an example and configure the parameters according to the API documentation.

../_images/api_backend.png


  1. In the Back-end Service page, enter the details for the following fields.

    • Back-end Service Address: The HTTP address and port that provide the API service.

    • HTTP Method: GET, POST, PUT, and DELETE are supported on EnOS currently.

    • Back-end Request Path: The path where the resource providing the API service is located.

    • Parameter Processing Mode: The processing mode of the API gateway for incoming parameters, where Pass-through and Mapping are supported.

      • Mapping: When the API gateway receives the API request from an API consumer, it converts the request into a format required by the backend through a mapping relationship.

      • Passthrough: After receiving the API request, the API gateway forwards it directly to the backend service rather than processing it.


    • Connect Timeout: The response time of the API gateway invoking the API back-end service when receiving the API request, i.e., the time from when the API gateway requests the back-end service to the time when the API gateway receives the response. The time is calculated in milliseconds. If the response time exceeds this value, the API gateway will stop requesting the back-end service and return an error message to the user. The default is 3,000 ms.

    • Read Timeout: The response time of the API gateway reading the API when receiving the API request. If the read time exceeds this value, the API gateway will stop the API request and return an error message to the user. The default is 60,000 ms.

    • Write Timeout: The timeout period for the interface to upload data after the API request reaches the API gateway. The unit is milliseconds. If the upload time exceeds this value, the API gateway will abandon the upload of the data and return the corresponding error message to the user. The default is 60,000 ms.

    • Files in the request body (when HTTP Method is POST or PUT): Select whether the request body contains a file.

      • No: Default

      • Yes

    • Files in the return body: Select whether the return body contains a file.

      • No: Default

      • Yes

    • Request Body Type (when HTTP Method is POST or PUT): Select the request body type.

      • None

      • Format

      • JsonBody


    • Back-end Parameters: The parameters that are required to invoke the back-end services. Taking the example of the Get Device API, the parameters include orgId and assetId.

      • Name: The name of the parameter.

      • Location: The location of the parameter in the request, which can be Head, Query, or Path.

      • Data Type: The data type of the parameter, for which String, Int, Long, Float, Double, Boolean, Binary, Date, DateTime, and Password are supported.

      • Required: Whether the parameter is mandatory or optional.

      • Default Value: The default value of the parameter, if any.

      • Description: The description of the parameter.


    • Constant Parameters: These parameters are invisible to API consumers. However, the API gateway will add these parameters to the specified location in the request when transferring the request, and then pass the request to the backend service to meet the backend business needs.

      • Name: The name of the constant parameter.

      • Location: The location of the constant parameter in the request, which can be Head or Query.

      • Mapping: Indicates whether this parameter is mapped to a fixed backend service.

      • Default Value: The default value of the constant parameter.

      • Description: The description of the constant parameter.


  2. Click Next.

Front-end Request

Configure the front-end service for the API and control the API version according to the naming standard of the API version iteration. If Pass-through is selected as the Parameter Processing Mode in the Back-end Service, then the Request Path in Front-end Request is consistent with that in the Backend Service.


  1. Enter the details for the following fields and click Next.

    • Version: This helps to identify different versions of the API. Different versions of the same API can be mounted under the same API group.

    • Request Path: The path used by the API consumer to invoke the API. If Mapping is selected for Parameter Processing Mode in the Back-end Service, the request path can be set by the API developer. If Pass-through is selected, the request path must be consistent with the path in Back-end Service.

    • Front-end Parameters: When Mapping is selected as Parameter Processing Mode, you need to set the parameter definition of the API request. The API parameter definition contains the following fields.

      • Front-end Name: The name of the parameter to be displayed to the API consumer.

      • Back-end Name: The backend parameter to which the parameter is mapped.

      • Front-end Location: The location of the parameter in the request.

      • Back-end Location: The location of the corresponding backend parameter in the request forwarded by the API gateway.

      • Data Type: The data type of the parameter.

      • Back-end Data Type: The corresponding backend data type.

      • Required: Whether the parameter is mandatory or optional.

      • Default Value: The default value of the parameter, if any.

      • Description: The description of the parameter.


    Among the above fields, some fields, including Name Required, Default Value, and Description, can be set by the user. Other fields are automatically matched with the corresponding fields of the Back-end Parameters in Back-end Service.


  2. Click Next.

Response

  1. On the Response page, enter the response information and error code.

    • Content Type

    • Success Sample

    • Failure Sample (Optional)

    • Error Code


  2. Click Next.

Advanced Configuration

API Management provides rich plugin services for every API. Click “+” to add plugins. The plugin services currently available include traffic control, black and white lists, and MOCK tests.


  1. In the Advanced Configuration page, you can add additional configurations for the API to be published in EnOS. The EnOS currently supports the following functions.

    • Network Traffic Control

      • Rate Limiting

      • Request Size Limiting

      • App Rate Limiting

    • IP Restriction

    • Mock


  2. Click OK.

Results

In the API group details page, you will be able to see the API that has been created successfully, with its status shown as Offline and the Visibility as Private.

Next Step

Deploying APIs