Unassign seats from users

DELETE https://api.ap1.datadoghq.com/api/v2/seats/usershttps://api.ap2.datadoghq.com/api/v2/seats/usershttps://api.datadoghq.eu/api/v2/seats/usershttps://api.ddog-gov.com/api/v2/seats/usershttps://api.us2.ddog-gov.com/api/v2/seats/usershttps://api.datadoghq.com/api/v2/seats/usershttps://api.us3.datadoghq.com/api/v2/seats/usershttps://api.us5.datadoghq.com/api/v2/seats/users

Overview

Unassign seats from users for a product code. This endpoint requires any of the following permissions:

  • billing_edit
  • incident_write
  • on_call_write

  • Request

    Body Data (required)

    Expand All

    Field

    Type

    Description

    data

    object

    The data for the unassign seats user request.

    attributes [required]

    object

    The attributes of the unassign seats user request.

    product_code [required]

    string

    The product code for which to unassign seats.

    user_uuids [required]

    [string]

    The list of user IDs to unassign seats from.

    id

    string

    The ID of the unassign seats user request.

    type [required]

    enum

    The type of the unassign seats user request. Allowed enum values: seat-assignments

    default: seat-assignments

    {
      "data": {
        "attributes": {
          "product_code": "",
          "user_uuids": [
            ""
          ]
        },
        "id": "string",
        "type": "seat-assignments"
      }
    }

    Response

    No Content

    Bad Request

    API error response.

    Expand All

    Field

    Type

    Description

    errors [required]

    [string]

    A list of errors.

    {
      "errors": [
        "Bad Request"
      ]
    }

    Unprocessable Entity

    API error response.

    Expand All

    Field

    Type

    Description

    errors [required]

    [string]

    A list of errors.

    {
      "errors": [
        "Bad Request"
      ]
    }

    Too many requests

    API error response.

    Expand All

    Field

    Type

    Description

    errors [required]

    [string]

    A list of errors.

    {
      "errors": [
        "Bad Request"
      ]
    }

    Code Example

                      ## default
    # 
    
    # Curl command
    curl -X DELETE "https://api.ap1.datadoghq.com"https://api.ap2.datadoghq.com"https://api.datadoghq.eu"https://api.ddog-gov.com"https://api.us2.ddog-gov.com"https://api.datadoghq.com"https://api.us3.datadoghq.com"https://api.us5.datadoghq.com/api/v2/seats/users" \ -H "Content-Type: application/json" \ -H "DD-API-KEY: ${DD_API_KEY}" \ -H "DD-APPLICATION-KEY: ${DD_APP_KEY}" \ -d @- << EOF { "data": { "attributes": { "product_code": "", "user_uuids": [ "626a4e8e-64bd-409d-b80e-428f08ac0b62" ] }, "type": "seat-assignments" } } EOF
    """
    Unassign seats from users returns "No Content" response
    """
    
    from os import environ
    from datadog_api_client import ApiClient, Configuration
    from datadog_api_client.v2.api.seats_api import SeatsApi
    from datadog_api_client.v2.model.seat_assignments_data_type import SeatAssignmentsDataType
    from datadog_api_client.v2.model.unassign_seats_user_request import UnassignSeatsUserRequest
    from datadog_api_client.v2.model.unassign_seats_user_request_data import UnassignSeatsUserRequestData
    from datadog_api_client.v2.model.unassign_seats_user_request_data_attributes import (
        UnassignSeatsUserRequestDataAttributes,
    )
    
    # there is a valid "user" in the system
    USER_DATA_ID = environ["USER_DATA_ID"]
    
    body = UnassignSeatsUserRequest(
        data=UnassignSeatsUserRequestData(
            type=SeatAssignmentsDataType.SEAT_ASSIGNMENTS,
            attributes=UnassignSeatsUserRequestDataAttributes(
                product_code="incident_response",
                user_uuids=[
                    USER_DATA_ID,
                ],
            ),
        ),
    )
    
    configuration = Configuration()
    with ApiClient(configuration) as api_client:
        api_instance = SeatsApi(api_client)
        api_instance.unassign_seats_user(body=body)
    

    Instructions

    First install the library and its dependencies and then save the example to example.py and run following commands:

        
    DD_SITE="datadoghq.comus3.datadoghq.comus5.datadoghq.comdatadoghq.euap1.datadoghq.comap2.datadoghq.comddog-gov.comus2.ddog-gov.com" DD_API_KEY="<API-KEY>" DD_APP_KEY="<APP-KEY>" python3 "example.py"
    # Unassign seats from users returns "No Content" response
    
    require "datadog_api_client"
    api_instance = DatadogAPIClient::V2::SeatsAPI.new
    
    # there is a valid "user" in the system
    USER_DATA_ID = ENV["USER_DATA_ID"]
    
    body = DatadogAPIClient::V2::UnassignSeatsUserRequest.new({
      data: DatadogAPIClient::V2::UnassignSeatsUserRequestData.new({
        type: DatadogAPIClient::V2::SeatAssignmentsDataType::SEAT_ASSIGNMENTS,
        attributes: DatadogAPIClient::V2::UnassignSeatsUserRequestDataAttributes.new({
          product_code: "incident_response",
          user_uuids: [
            USER_DATA_ID,
          ],
        }),
      }),
    })
    api_instance.unassign_seats_user(body)
    

    Instructions

    First install the library and its dependencies and then save the example to example.rb and run following commands:

        
    DD_SITE="datadoghq.comus3.datadoghq.comus5.datadoghq.comdatadoghq.euap1.datadoghq.comap2.datadoghq.comddog-gov.comus2.ddog-gov.com" DD_API_KEY="<API-KEY>" DD_APP_KEY="<APP-KEY>" rb "example.rb"
    // Unassign seats from users returns "No Content" response
    
    package main
    
    import (
    	"context"
    	"fmt"
    	"os"
    
    	"github.com/DataDog/datadog-api-client-go/v2/api/datadog"
    	"github.com/DataDog/datadog-api-client-go/v2/api/datadogV2"
    )
    
    func main() {
    	// there is a valid "user" in the system
    	UserDataID := os.Getenv("USER_DATA_ID")
    
    	body := datadogV2.UnassignSeatsUserRequest{
    		Data: &datadogV2.UnassignSeatsUserRequestData{
    			Type: datadogV2.SEATASSIGNMENTSDATATYPE_SEAT_ASSIGNMENTS,
    			Attributes: datadogV2.UnassignSeatsUserRequestDataAttributes{
    				ProductCode: "incident_response",
    				UserUuids: []string{
    					UserDataID,
    				},
    			},
    		},
    	}
    	ctx := datadog.NewDefaultContext(context.Background())
    	configuration := datadog.NewConfiguration()
    	apiClient := datadog.NewAPIClient(configuration)
    	api := datadogV2.NewSeatsApi(apiClient)
    	r, err := api.UnassignSeatsUser(ctx, body)
    
    	if err != nil {
    		fmt.Fprintf(os.Stderr, "Error when calling `SeatsApi.UnassignSeatsUser`: %v\n", err)
    		fmt.Fprintf(os.Stderr, "Full HTTP response: %v\n", r)
    	}
    }
    

    Instructions

    First install the library and its dependencies and then save the example to main.go and run following commands:

        
    DD_SITE="datadoghq.comus3.datadoghq.comus5.datadoghq.comdatadoghq.euap1.datadoghq.comap2.datadoghq.comddog-gov.comus2.ddog-gov.com" DD_API_KEY="<API-KEY>" DD_APP_KEY="<APP-KEY>" go run "main.go"
    // Unassign seats from users returns "No Content" response
    
    import com.datadog.api.client.ApiClient;
    import com.datadog.api.client.ApiException;
    import com.datadog.api.client.v2.api.SeatsApi;
    import com.datadog.api.client.v2.model.SeatAssignmentsDataType;
    import com.datadog.api.client.v2.model.UnassignSeatsUserRequest;
    import com.datadog.api.client.v2.model.UnassignSeatsUserRequestData;
    import com.datadog.api.client.v2.model.UnassignSeatsUserRequestDataAttributes;
    import java.util.Collections;
    
    public class Example {
      public static void main(String[] args) {
        ApiClient defaultClient = ApiClient.getDefaultApiClient();
        SeatsApi apiInstance = new SeatsApi(defaultClient);
    
        // there is a valid "user" in the system
        String USER_DATA_ID = System.getenv("USER_DATA_ID");
    
        UnassignSeatsUserRequest body =
            new UnassignSeatsUserRequest()
                .data(
                    new UnassignSeatsUserRequestData()
                        .type(SeatAssignmentsDataType.SEAT_ASSIGNMENTS)
                        .attributes(
                            new UnassignSeatsUserRequestDataAttributes()
                                .productCode("incident_response")
                                .userUuids(Collections.singletonList(USER_DATA_ID))));
    
        try {
          apiInstance.unassignSeatsUser(body);
        } catch (ApiException e) {
          System.err.println("Exception when calling SeatsApi#unassignSeatsUser");
          System.err.println("Status code: " + e.getCode());
          System.err.println("Reason: " + e.getResponseBody());
          System.err.println("Response headers: " + e.getResponseHeaders());
          e.printStackTrace();
        }
      }
    }
    

    Instructions

    First install the library and its dependencies and then save the example to Example.java and run following commands:

        
    DD_SITE="datadoghq.comus3.datadoghq.comus5.datadoghq.comdatadoghq.euap1.datadoghq.comap2.datadoghq.comddog-gov.comus2.ddog-gov.com" DD_API_KEY="<API-KEY>" DD_APP_KEY="<APP-KEY>" java "Example.java"
    // Unassign seats from users returns "No Content" response
    use datadog_api_client::datadog;
    use datadog_api_client::datadogV2::api_seats::SeatsAPI;
    use datadog_api_client::datadogV2::model::SeatAssignmentsDataType;
    use datadog_api_client::datadogV2::model::UnassignSeatsUserRequest;
    use datadog_api_client::datadogV2::model::UnassignSeatsUserRequestData;
    use datadog_api_client::datadogV2::model::UnassignSeatsUserRequestDataAttributes;
    
    #[tokio::main]
    async fn main() {
        // there is a valid "user" in the system
        let user_data_id = std::env::var("USER_DATA_ID").unwrap();
        let body = UnassignSeatsUserRequest::new().data(UnassignSeatsUserRequestData::new(
            UnassignSeatsUserRequestDataAttributes::new(
                "incident_response".to_string(),
                vec![user_data_id.clone()],
            ),
            SeatAssignmentsDataType::SEAT_ASSIGNMENTS,
        ));
        let configuration = datadog::Configuration::new();
        let api = SeatsAPI::with_config(configuration);
        let resp = api.unassign_seats_user(body).await;
        if let Ok(value) = resp {
            println!("{:#?}", value);
        } else {
            println!("{:#?}", resp.unwrap_err());
        }
    }
    

    Instructions

    First install the library and its dependencies and then save the example to src/main.rs and run following commands:

        
    DD_SITE="datadoghq.comus3.datadoghq.comus5.datadoghq.comdatadoghq.euap1.datadoghq.comap2.datadoghq.comddog-gov.comus2.ddog-gov.com" DD_API_KEY="<API-KEY>" DD_APP_KEY="<APP-KEY>" cargo run
    /**
     * Unassign seats from users returns "No Content" response
     */
    
    import { client, v2 } from "@datadog/datadog-api-client";
    
    const configuration = client.createConfiguration();
    const apiInstance = new v2.SeatsApi(configuration);
    
    // there is a valid "user" in the system
    const USER_DATA_ID = process.env.USER_DATA_ID as string;
    
    const params: v2.SeatsApiUnassignSeatsUserRequest = {
      body: {
        data: {
          type: "seat-assignments",
          attributes: {
            productCode: "incident_response",
            userUuids: [USER_DATA_ID],
          },
        },
      },
    };
    
    apiInstance
      .unassignSeatsUser(params)
      .then((data: any) => {
        console.log(
          "API called successfully. Returned data: " + JSON.stringify(data)
        );
      })
      .catch((error: any) => console.error(error));
    

    Instructions

    First install the library and its dependencies and then save the example to example.ts and run following commands:

        
    DD_SITE="datadoghq.comus3.datadoghq.comus5.datadoghq.comdatadoghq.euap1.datadoghq.comap2.datadoghq.comddog-gov.comus2.ddog-gov.com" DD_API_KEY="<API-KEY>" DD_APP_KEY="<APP-KEY>" tsc "example.ts"