Updated on 2024-11-06 GMT+08:00

Querying an API List

Function

This API is used to query the API list.

Calling Method

For details, see Calling APIs.

URI

GET /v1/{project_id}/service/apis

Table 1 Path Parameters

Parameter

Mandatory

Type

Description

project_id

Yes

String

Project ID. For details about how to obtain the project ID, see Project ID and Account ID.

Table 2 Query Parameters

Parameter

Mandatory

Type

Description

offset

No

Integer

Query start coordinate, that is, skipping the first X records. The value can only be 0 or an integer multiple of limit. If the requirement is not met, the value is rounded down.

limit

No

Integer

Maximum number of records that can be queried

name

No

String

Fuzzy query based on the API name.

description

No

String

Fuzzy query based on the API description.

create_user

No

String

Create a user fuzzy query based on the API.

start_time

No

String

Start time, which is accurate to second, complies with RFC3339, and uses the UTC time zone, for example, 2024-02-24T16:00:00.000Z

end_time

No

String

End time, which is accurate to second, complies with RFC3339, and uses the UTC time zone, for example, 2024-04-05T15:59:59.998Z

tags

No

Array of strings

Tag

api_type

No

String

API type

Enumerated values include:

  • API_SPECIFIC_TYPE_CONFIGURATION: configuration API

  • API_SPECIFIC_TYPE_SCRIPT: script API

  • API_SPECIFIC_TYPE_MYBATIS: MyBatis API

  • API_SPECIFIC_TYPE_GROOVY: Groovy API

  • API_SPECIFIC_TYPE_REGISTER: registered API

  • API_SPECIFIC_TYPE_ORCHESTRATE: orchestrated API

publish_status

No

String

API publishing status

Enumerated values include:

  • PUBLISHED: published

  • NOT_PUBLISHED: unpublished

table_name

No

String

Fuzzy query based on the database table name used by the API.

authorization_status

No

String

Authorization status.

Enumerated values:

  • NO_AUTHORIZATION_REQUIRED: no authorization required

  • UNAUTHORIZED: unauthorized

  • AUTHORIZED: authorized

Request Parameters

Table 3 Request header parameters

Parameter

Mandatory

Type

Description

X-Auth-Token

Yes

String

User token. This parameter is mandatory when token authentication is used. You can obtain it from the value of X-Subject-Token in the response message header returned by the "Obtaining a User Token" API of the IAM service.

workspace

Yes

String

Workspace ID. For details about how to obtain the workspace ID, see Instance ID and Workspace ID.

Dlm-Type

No

String

Specifies the version type of the data service. The value can be SHARED or EXCLUSIVE.

Content-Type

Yes

String

Type (format) of the message body. This parameter is mandatory if the message body exists. If the message body does not exist, leave this parameter blank. If the request body contains Chinese characters, use charset=utf8 to specify the Chinese character set, for example, application/json;charset=utf8.

x-return-publish-messages

No

String

Specifies whether to return the publishing information of the exclusive API.

Response Parameters

Status code: 200

Table 4 Response body parameters

Parameter

Type

Description

total

Integer

Total number of APIs.

records

Array of ApiOverview objects

API list.

Table 5 ApiOverview

Parameter

Type

Description

id

String

API ID.

name

String

API name

group_id

String

API group ID (shared version).

description

String

API description,

status

String

API status (DataArts DataService Shared)

Enumerated values:

  • API_STATUS_CREATED: created

  • API_STATUS_PUBLISH_WAIT_REVIEW: waiting for review

  • API_STATUS_PUBLISH_REJECT: rejected

  • API_STATUS_PUBLISHED: published

  • API_STATUS_WAITING_STOP: waiting to be stopped

  • API_STATUS_STOPPED: stopped

  • API_STATUS_RECOVER_WAIT_REVIEW: waiting to be recovered

  • API_STATUS_WAITING_OFFLINE: waiting to be suspended

  • API_STATUS_OFFLINE: suspended

  • API_STATUS_OFFLINE_WAIT_REVIEW: waiting to be reviewed for suspension

debug_status

String

API debugging status (DataArts DataService Shared)

Enumerated values:

  • API_DEBUG_WAITING: waiting to be debugged

  • API_DEBUG_FAILED: debugging failed

  • API_DEBUG_SUCCESS: debugging successful

publish_messages

Array of ApiPublishDTO objects

Release information list (exclusive edition).

type

String

API type.

manager

String

API reviewer.

create_user

String

API creator.

create_time

Long

API creation time

authorization_status

String

Authorization status.

Enumerated values:

  • NO_AUTHORIZATION_REQUIRED: no authorization required

  • UNAUTHORIZED: unauthorized

  • AUTHORIZED: authorized

Table 6 ApiPublishDTO

Parameter

Type

Description

id

String

Release ID.

api_id

String

API ID

instance_id

String

Cluster ID

instance_name

String

Cluster Name

api_status

String

API status (DataArts DataService Shared)

Enumerated values:

  • API_STATUS_CREATED: created

  • API_STATUS_PUBLISH_WAIT_REVIEW: waiting for review

  • API_STATUS_PUBLISH_REJECT: rejected

  • API_STATUS_PUBLISHED: published

  • API_STATUS_WAITING_STOP: waiting to be stopped

  • API_STATUS_STOPPED: stopped

  • API_STATUS_RECOVER_WAIT_REVIEW: waiting to be recovered

  • API_STATUS_WAITING_OFFLINE: waiting to be suspended

  • API_STATUS_OFFLINE: suspended

  • API_STATUS_OFFLINE_WAIT_REVIEW: waiting to be reviewed for suspension

api_debug

String

API debugging status (DataArts DataService Shared)

Enumerated values:

  • API_DEBUG_WAITING: waiting to be debugged

  • API_DEBUG_FAILED: debugging failed

  • API_DEBUG_SUCCESS: debugging successful

Status code: 400

Table 7 Response body parameters

Parameter

Type

Description

error_code

String

Error code.

error_msg

String

Error message.

Example Requests

Query the information about a script API created and published by the administrator.

/v1/0833a5737480d53b2f250010d01a7b88/service/apis?api_type=API_SPECIFIC_TYPE_SCRIPT&publish_status=PUBLISHED&create_user=admin&description=test

{
  "api_type" : "API_SPECIFIC_TYPE_SCRIPT",
  "publish_status" : "PUBLISHED",
  "create_user" : "admin",
  "description" : "Test"
}

Example Responses

Status code: 200

Success

{
  "total" : 1,
  "records" : [ {
    "id" : "fd0beac79418d65e3b3ed24a6e53b24b",
    "name" : "testApi",
    "create_time" : 1579162215000,
    "status" : "API_STATUS_CREATED",
    "manager" : "admin",
    "type" : "API_SPECIFIC_TYPE_REGISTER",
    "debug_status" : "API_DEBUG_WAITING",
    "description" : "api description"
  } ]
}

SDK Sample Code

The SDK sample code is as follows.

Query the information about a script API created and published by the administrator.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package com.huaweicloud.sdk.test;

import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.BasicCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.dataartsstudio.v1.region.DataArtsStudioRegion;
import com.huaweicloud.sdk.dataartsstudio.v1.*;
import com.huaweicloud.sdk.dataartsstudio.v1.model.*;


public class ListApisSolution {

    public static void main(String[] args) {
        // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
        // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
        String ak = System.getenv("CLOUD_SDK_AK");
        String sk = System.getenv("CLOUD_SDK_SK");
        String projectId = "{project_id}";

        ICredential auth = new BasicCredentials()
                .withProjectId(projectId)
                .withAk(ak)
                .withSk(sk);

        DataArtsStudioClient client = DataArtsStudioClient.newBuilder()
                .withCredential(auth)
                .withRegion(DataArtsStudioRegion.valueOf("<YOUR REGION>"))
                .build();
        ListApisRequest request = new ListApisRequest();
        try {
            ListApisResponse response = client.listApis(request);
            System.out.println(response.toString());
        } catch (ConnectionException e) {
            e.printStackTrace();
        } catch (RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println(e.getHttpStatusCode());
            System.out.println(e.getRequestId());
            System.out.println(e.getErrorCode());
            System.out.println(e.getErrorMsg());
        }
    }
}

Query the information about a script API created and published by the administrator.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# coding: utf-8

import os
from huaweicloudsdkcore.auth.credentials import BasicCredentials
from huaweicloudsdkdataartsstudio.v1.region.dataartsstudio_region import DataArtsStudioRegion
from huaweicloudsdkcore.exceptions import exceptions
from huaweicloudsdkdataartsstudio.v1 import *

if __name__ == "__main__":
    # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak = os.environ["CLOUD_SDK_AK"]
    sk = os.environ["CLOUD_SDK_SK"]
    projectId = "{project_id}"

    credentials = BasicCredentials(ak, sk, projectId)

    client = DataArtsStudioClient.new_builder() \
        .with_credentials(credentials) \
        .with_region(DataArtsStudioRegion.value_of("<YOUR REGION>")) \
        .build()

    try:
        request = ListApisRequest()
        response = client.list_apis(request)
        print(response)
    except exceptions.ClientRequestException as e:
        print(e.status_code)
        print(e.request_id)
        print(e.error_code)
        print(e.error_msg)

Query the information about a script API created and published by the administrator.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package main

import (
	"fmt"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic"
    dataartsstudio "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dataartsstudio/v1"
	"github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dataartsstudio/v1/model"
    region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dataartsstudio/v1/region"
)

func main() {
    // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security.
    // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment
    ak := os.Getenv("CLOUD_SDK_AK")
    sk := os.Getenv("CLOUD_SDK_SK")
    projectId := "{project_id}"

    auth := basic.NewCredentialsBuilder().
        WithAk(ak).
        WithSk(sk).
        WithProjectId(projectId).
        Build()

    client := dataartsstudio.NewDataArtsStudioClient(
        dataartsstudio.DataArtsStudioClientBuilder().
            WithRegion(region.ValueOf("<YOUR REGION>")).
            WithCredential(auth).
            Build())

    request := &model.ListApisRequest{}
	response, err := client.ListApis(request)
	if err == nil {
        fmt.Printf("%+v\n", response)
    } else {
        fmt.Println(err)
    }
}

For SDK sample code of more programming languages, see the Sample Code tab in API Explorer. SDK sample code can be automatically generated.

Status Codes

Status Code

Description

200

Success

400

Bad request