# DestroyPort

## 1. API Description

This API is used to release a port.

#### Prerequisites

Before releasing a port, you can call [`DescribePorts`](https://docs.console.zenlayer.com/api-reference/networking/sdn/describeports#DescribePorts) to query port list.

{% hint style="info" %} <mark style="color:blue;">**Note**</mark>

* <mark style="color:blue;">This operation is irreversible. Once the operation is successful, the port will be completely released. Please operate with caution.</mark>
* <mark style="color:blue;">Only operations on ports in recycle bin are supported.</mark>
* <mark style="color:blue;">This API is an async API. A request ID is returned after the release request is sent. However, it does not mean the releasing has been completed. The status of the port will be</mark> <mark style="color:blue;">`DESTROYING`</mark> <mark style="color:blue;">during the releasing. You can use</mark> [<mark style="color:purple;">`DescribePorts`</mark>](https://docs.console.zenlayer.com/api-reference/networking/sdn/describeports#describeports) <mark style="color:blue;">to query the status of the port. If the status of the port changes</mark> <mark style="color:blue;">`DESTROYING`</mark> <mark style="color:blue;">to</mark> <mark style="color:blue;">`DESTROYED`</mark><mark style="color:blue;">, it means that the port has been released successfully. Any operations on the port are not allowed while releasing.</mark>
  {% endhint %}

## 2. Input Parameters

The following request parameter list only provides API request parameters.

<table><thead><tr><th width="198">Parameter Name</th><th width="128">Required</th><th width="119">Type</th><th>Description</th></tr></thead><tbody><tr><td>portId</td><td>Yes</td><td>String</td><td>Port ID.</td></tr></tbody></table>

## 3. Output Parameters

<table><thead><tr><th width="200.33333333333331">Parameter Name</th><th width="112">Type</th><th>Description</th></tr></thead><tbody><tr><td>requestId</td><td>String</td><td>The unique request ID, which is returned for each request. RequestId is required for locating a problem.</td></tr></tbody></table>

## 4. Code Example

{% tabs %}
{% tab title="Example" %}
**Release a port.**

```json
POST /api/v2/sdn HTTP/1.1
Host: console.zenlayer.com
Content-Type: application/json
X-ZC-Action: DestroyPort
<Common Request Params>

Request:
{
  "portId": "your-port-id"
}

Response:
{
  "requestId": "T3811A0E7-C250-40A2-96AD-08AD759E1BC2",
  "response": {
    "requestId": "T3811A0E7-C250-40A2-96AD-08AD759E1BC2"
  }
}
```

{% endtab %}
{% endtabs %}

## 5. Developer Resources

Zenlayer Cloud API 2.0 integrates [SDKs](https://docs.console.zenlayer.com/api-reference/api-introduction/toolkit/api-sdk) to make it easier for you to call APIs. More programming languages will be supported.

## 6. Error Codes

The following only lists the error codes related to the API business logic. For other error codes, see [Common Error Codes](https://docs.console.zenlayer.com/api-reference/api-introduction/instruction/commonerrorcode).​

<table><thead><tr><th width="210.33333333333331">HTTP Status Code</th><th width="303">Error Code</th><th>Description</th></tr></thead><tbody><tr><td>7105</td><td>SELF_SERVICE_PORT_NOT_FOUND</td><td>Port not found.</td></tr></tbody></table>
