Publish status page

POST https://api.ap1.datadoghq.com/api/v2/statuspages/{page_id}/publishhttps://api.ap2.datadoghq.com/api/v2/statuspages/{page_id}/publishhttps://api.datadoghq.eu/api/v2/statuspages/{page_id}/publishhttps://api.ddog-gov.com/api/v2/statuspages/{page_id}/publishhttps://api.us2.ddog-gov.com/api/v2/statuspages/{page_id}/publishhttps://api.datadoghq.com/api/v2/statuspages/{page_id}/publishhttps://api.us3.datadoghq.com/api/v2/statuspages/{page_id}/publishhttps://api.us5.datadoghq.com/api/v2/statuspages/{page_id}/publish

Overview

Publishes a status page. For pages of type public, makes the status page available on the public internet and requires the status_pages_public_page_publish permission. For pages of type internal, makes the status page available under the status-pages/$domain_prefix/view route within the Datadog organization and requires the status_pages_internal_page_publish permission. The status_pages_settings_write permission is temporarily honored as we migrate publishing functionality from the update status page endpoint to the publish status page endpoint. This endpoint requires any of the following permissions:

  • status_pages_settings_write
  • status_pages_public_page_publish
  • status_pages_internal_page_publish

  • Arguments

    Path Parameters

    Name

    Type

    Description

    page_id [required]

    string

    The ID of the status page.

    Response

    No Content

    Too many requests

    API error response.

    Expand All

    Field

    Type

    Description

    errors [required]

    [string]

    A list of errors.

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

    Code Example

                      # Path parameters
    export page_id="CHANGE_ME"
    # Curl command
    curl -X POST "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/statuspages/${page_id}/publish" \ -H "DD-API-KEY: ${DD_API_KEY}" \ -H "DD-APPLICATION-KEY: ${DD_APP_KEY}"
    """
    Publish status page returns "No Content" response
    """
    
    from os import environ
    from datadog_api_client import ApiClient, Configuration
    from datadog_api_client.v2.api.status_pages_api import StatusPagesApi
    
    # there is a valid "status_page" in the system
    STATUS_PAGE_DATA_ID = environ["STATUS_PAGE_DATA_ID"]
    
    configuration = Configuration()
    with ApiClient(configuration) as api_client:
        api_instance = StatusPagesApi(api_client)
        api_instance.publish_status_page(
            page_id=STATUS_PAGE_DATA_ID,
        )
    

    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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" python3 "example.py"
    # Publish status page returns "No Content" response
    
    require "datadog_api_client"
    api_instance = DatadogAPIClient::V2::StatusPagesAPI.new
    
    # there is a valid "status_page" in the system
    STATUS_PAGE_DATA_ID = ENV["STATUS_PAGE_DATA_ID"]
    api_instance.publish_status_page(STATUS_PAGE_DATA_ID)
    

    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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" rb "example.rb"
    // Publish status page 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"
    	"github.com/google/uuid"
    )
    
    func main() {
    	// there is a valid "status_page" in the system
    	StatusPageDataID := uuid.MustParse(os.Getenv("STATUS_PAGE_DATA_ID"))
    
    	ctx := datadog.NewDefaultContext(context.Background())
    	configuration := datadog.NewConfiguration()
    	apiClient := datadog.NewAPIClient(configuration)
    	api := datadogV2.NewStatusPagesApi(apiClient)
    	r, err := api.PublishStatusPage(ctx, StatusPageDataID)
    
    	if err != nil {
    		fmt.Fprintf(os.Stderr, "Error when calling `StatusPagesApi.PublishStatusPage`: %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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" go run "main.go"
    // Publish status page returns "No Content" response
    
    import com.datadog.api.client.ApiClient;
    import com.datadog.api.client.ApiException;
    import com.datadog.api.client.v2.api.StatusPagesApi;
    import java.util.UUID;
    
    public class Example {
      public static void main(String[] args) {
        ApiClient defaultClient = ApiClient.getDefaultApiClient();
        StatusPagesApi apiInstance = new StatusPagesApi(defaultClient);
    
        // there is a valid "status_page" in the system
        UUID STATUS_PAGE_DATA_ID = null;
        try {
          STATUS_PAGE_DATA_ID = UUID.fromString(System.getenv("STATUS_PAGE_DATA_ID"));
        } catch (IllegalArgumentException e) {
          System.err.println("Error parsing UUID: " + e.getMessage());
        }
    
        try {
          apiInstance.publishStatusPage(STATUS_PAGE_DATA_ID);
        } catch (ApiException e) {
          System.err.println("Exception when calling StatusPagesApi#publishStatusPage");
          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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" java "Example.java"
    // Publish status page returns "No Content" response
    use datadog_api_client::datadog;
    use datadog_api_client::datadogV2::api_status_pages::StatusPagesAPI;
    
    #[tokio::main]
    async fn main() {
        // there is a valid "status_page" in the system
        let status_page_data_id = uuid::Uuid::parse_str(&std::env::var("STATUS_PAGE_DATA_ID").unwrap())
            .expect("Invalid UUID");
        let configuration = datadog::Configuration::new();
        let api = StatusPagesAPI::with_config(configuration);
        let resp = api.publish_status_page(status_page_data_id.clone()).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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" cargo run
    /**
     * Publish status page returns "No Content" response
     */
    
    import { client, v2 } from "@datadog/datadog-api-client";
    
    const configuration = client.createConfiguration();
    const apiInstance = new v2.StatusPagesApi(configuration);
    
    // there is a valid "status_page" in the system
    const STATUS_PAGE_DATA_ID = process.env.STATUS_PAGE_DATA_ID as string;
    
    const params: v2.StatusPagesApiPublishStatusPageRequest = {
      pageId: STATUS_PAGE_DATA_ID,
    };
    
    apiInstance
      .publishStatusPage(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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" tsc "example.ts"