Attach security findings to a Jira issue

PATCH https://api.ap1.datadoghq.com/api/v2/security/findings/jira_issueshttps://api.ap2.datadoghq.com/api/v2/security/findings/jira_issueshttps://api.datadoghq.eu/api/v2/security/findings/jira_issueshttps://api.ddog-gov.com/api/v2/security/findings/jira_issueshttps://api.us2.ddog-gov.com/api/v2/security/findings/jira_issueshttps://api.datadoghq.com/api/v2/security/findings/jira_issueshttps://api.us3.datadoghq.com/api/v2/security/findings/jira_issueshttps://api.us5.datadoghq.com/api/v2/security/findings/jira_issues

Overview

Attach security findings to a Jira issue by providing the Jira issue URL. You can attach up to 50 security findings per Jira issue. If the Jira issue is not linked to any case, this operation will create a case for the security findings and link the Jira issue to the newly created case. To configure the Jira integration, see Bidirectional ticket syncing with Jira. Security findings that are already attached to another Jira issue will be detached from their previous Jira issue and attached to the specified Jira issue. This endpoint requires any of the following permissions:

  • security_monitoring_findings_write
  • appsec_vm_write

  • Request

    Body Data (required)

    Expand All

    Field

    Type

    Description

    data

    object

    Data of the Jira issue to attach security findings to.

    attributes

    object

    Attributes of the Jira issue to attach security findings to.

    jira_issue_url [required]

    string

    URL of the Jira issue to attach security findings to.

    relationships

    object

    Relationships of the Jira issue to attach security findings to.

    findings [required]

    object

    Security findings to attach to the Jira issue.

    data

    [object]

    Array of security finding data objects.

    id [required]

    string

    Unique identifier of the security finding.

    type [required]

    enum

    Security findings resource type. Allowed enum values: findings

    default: findings

    project [required]

    object

    Case management project with Jira integration configured. It is used to attach security findings to the Jira issue. To configure the integration, see Bidirectional ticket syncing with Jira.

    data [required]

    object

    Data object representing a case management project.

    id [required]

    string

    Unique identifier of the case management project.

    type [required]

    enum

    Projects resource type. Allowed enum values: projects

    default: projects

    type [required]

    enum

    Jira issues resource type. Allowed enum values: jira_issues

    default: jira_issues

    {
      "data": {
        "attributes": {
          "jira_issue_url": "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476"
        },
        "relationships": {
          "findings": {
            "data": [
              {
                "id": "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                "type": "findings"
              }
            ]
          },
          "project": {
            "data": {
              "id": "959a6f71-bac8-4027-b1d3-2264f569296f",
              "type": "projects"
            }
          }
        },
        "type": "jira_issues"
      }
    }
    {
      "data": {
        "attributes": {
          "jira_issue_url": "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476"
        },
        "relationships": {
          "findings": {
            "data": [
              {
                "id": "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                "type": "findings"
              },
              {
                "id": "MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=",
                "type": "findings"
              }
            ]
          },
          "project": {
            "data": {
              "id": "959a6f71-bac8-4027-b1d3-2264f569296f",
              "type": "projects"
            }
          }
        },
        "type": "jira_issues"
      }
    }

    Response

    OK

    Case response.

    Expand All

    Field

    Type

    Description

    data

    object

    Data of the case.

    attributes

    object

    Attributes of the case.

    archived_at

    date-time

    Timestamp of when the case was archived.

    assigned_to

    object

    User assigned to the case.

    data [required]

    object

    Relationship to user object.

    id [required]

    string

    A unique identifier that represents the user.

    type [required]

    enum

    Users resource type. Allowed enum values: users

    default: users

    attributes

    object

    Custom attributes associated with the case as key-value pairs where values are string arrays.

    <any-key>

    [string]

    closed_at

    date-time

    Timestamp of when the case was closed.

    created_at

    date-time

    Timestamp of when the case was created.

    creation_source

    string

    Source of the case creation.

    description

    string

    Description of the case.

    due_date

    string

    Due date of the case.

    insights

    [object]

    Insights of the case.

    ref

    string

    Reference of the insight.

    resource_id

    string

    Unique identifier of the resource. For example, the unique identifier of a security finding.

    type

    string

    Type of the resource. For example, the type of a security finding is "SECURITY_FINDING".

    jira_issue

    object

    Jira issue associated with the case.

    error_message

    string

    Error message if the Jira issue creation failed.

    result

    object

    Result of the Jira issue creation.

    account_id

    string

    Account ID of the Jira issue.

    issue_id

    string

    Unique identifier of the Jira issue.

    issue_key

    string

    Key of the Jira issue.

    issue_url

    string

    URL of the Jira issue.

    status

    string

    Status of the Jira issue creation. Can be "COMPLETED" if the Jira issue was created successfully, or "FAILED" if the Jira issue creation failed.

    key

    string

    Key of the case.

    modified_at

    date-time

    Timestamp of when the case was last modified.

    priority

    string

    Priority of the case.

    servicenow_ticket

    object

    ServiceNow ticket associated with the case.

    result

    object

    Result of the ServiceNow ticket creation or attachment.

    instance_name

    string

    ServiceNow instance name extracted from the ticket URL.

    sys_id

    string

    Unique identifier of the ServiceNow incident record.

    sys_target_link

    string

    Direct link to the ServiceNow incident record.

    sys_target_sys_id

    string

    Unique identifier of the target ServiceNow record.

    table_name

    string

    ServiceNow table containing the incident record.

    url

    string

    URL of the ServiceNow incident record.

    status

    string

    Status of the ServiceNow ticket operation. Can be "COMPLETED" if successful, or "FAILED" if the operation failed.

    status

    string

    Status of the case.

    status_group

    string

    Status group of the case.

    status_name

    string

    Status name of the case.

    title

    string

    Title of the case.

    type

    string

    Type of the case. For security cases, this is always "SECURITY".

    id

    string

    Unique identifier of the case.

    relationships

    object

    Relationships of the case.

    created_by

    object

    User who created the case.

    data [required]

    object

    Relationship to user object.

    id [required]

    string

    A unique identifier that represents the user.

    type [required]

    enum

    Users resource type. Allowed enum values: users

    default: users

    modified_by

    object

    User who last modified the case.

    data [required]

    object

    Relationship to user object.

    id [required]

    string

    A unique identifier that represents the user.

    type [required]

    enum

    Users resource type. Allowed enum values: users

    default: users

    project

    object

    Project in which the case was created.

    data [required]

    object

    Data object representing a case management project.

    id [required]

    string

    Unique identifier of the case management project.

    type [required]

    enum

    Projects resource type. Allowed enum values: projects

    default: projects

    type [required]

    enum

    Cases resource type. Allowed enum values: cases

    default: cases

    {
      "data": {
        "attributes": {
          "archived_at": "2025-01-01T00:00:00.000Z",
          "assigned_to": {
            "data": {
              "id": "00000000-0000-0000-2345-000000000000",
              "type": "users"
            }
          },
          "attributes": {
            "<any-key>": []
          },
          "closed_at": "2025-01-01T00:00:00.000Z",
          "created_at": "2025-01-01T00:00:00.000Z",
          "creation_source": "CS_SECURITY_FINDING",
          "description": "A description of the case.",
          "due_date": "2025-01-01",
          "insights": [
            {
              "ref": "/security/appsec/vm/library/vulnerability/dfa027f7c037b2f77159adc027fecb56?detection=static",
              "resource_id": "ZGVmLTAwcC1pZXJ-aS0wZjhjNjMyZDNmMzRlZTgzNw==",
              "type": "SECURITY_FINDING"
            }
          ],
          "jira_issue": {
            "error_message": "{\"errorMessages\":[\"An error occured.\"],\"errors\":{}}",
            "result": {
              "account_id": "463a8631-680e-455c-bfd3-3ed04d326eb7",
              "issue_id": "2871276",
              "issue_key": "PROJ-123",
              "issue_url": "https://domain.atlassian.net/browse/PROJ-123"
            },
            "status": "COMPLETED"
          },
          "key": "PROJ-123",
          "modified_at": "2025-01-01T00:00:00.000Z",
          "priority": "P4",
          "servicenow_ticket": {
            "result": {
              "instance_name": "example",
              "sys_id": "abcdef0123456789abcdef0123456789",
              "sys_target_link": "https://example.service-now.com/incident.do?sys_id=abcdef0123456789abcdef0123456789",
              "sys_target_sys_id": "abcdef0123456789abcdef0123456789",
              "table_name": "incident",
              "url": "https://example.service-now.com/now/nav/ui/classic/params/target/incident.do?sys_id=abcdef0123456789abcdef0123456789"
            },
            "status": "COMPLETED"
          },
          "status": "OPEN",
          "status_group": "SG_OPEN",
          "status_name": "Open",
          "title": "A title for the case.",
          "type": "SECURITY"
        },
        "id": "c1234567-89ab-cdef-0123-456789abcdef",
        "relationships": {
          "created_by": {
            "data": {
              "id": "00000000-0000-0000-2345-000000000000",
              "type": "users"
            }
          },
          "modified_by": {
            "data": {
              "id": "00000000-0000-0000-2345-000000000000",
              "type": "users"
            }
          },
          "project": {
            "data": {
              "id": "aeadc05e-98a8-11ec-ac2c-da7ad0900001",
              "type": "projects"
            }
          }
        },
        "type": "cases"
      }
    }

    Bad Request

    API error response.

    Expand All

    Field

    Type

    Description

    errors [required]

    [string]

    A list of errors.

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

    Not Found

    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 PATCH "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/security/findings/jira_issues" \ -H "Accept: application/json" \ -H "Content-Type: application/json" \ -H "DD-API-KEY: ${DD_API_KEY}" \ -H "DD-APPLICATION-KEY: ${DD_APP_KEY}" \ -d @- << EOF { "data": { "attributes": { "jira_issue_url": "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476" }, "relationships": { "findings": { "data": [ { "id": "ZGVmLTAwcC1pZXJ-aS0wZjhjNjMyZDNmMzRlZTgzNw==" } ] }, "project": { "data": { "id": "aeadc05e-98a8-11ec-ac2c-da7ad0900001", "type": "projects" } } }, "type": "jira_issues" } } EOF
                              ## default
    # 
    
    # Curl command
    curl -X PATCH "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/security/findings/jira_issues" \ -H "Accept: application/json" \ -H "Content-Type: application/json" \ -H "DD-API-KEY: ${DD_API_KEY}" \ -H "DD-APPLICATION-KEY: ${DD_APP_KEY}" \ -d @- << EOF { "data": { "attributes": { "jira_issue_url": "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476" }, "relationships": { "findings": { "data": [ { "id": "ZGVmLTAwcC1pZXJ-aS0wZjhjNjMyZDNmMzRlZTgzNw==" } ] }, "project": { "data": { "id": "aeadc05e-98a8-11ec-ac2c-da7ad0900001", "type": "projects" } } }, "type": "jira_issues" } } EOF
    // Attach security finding to a Jira issue returns "OK" response
    
    package main
    
    import (
    	"context"
    	"encoding/json"
    	"fmt"
    	"os"
    
    	"github.com/DataDog/datadog-api-client-go/v2/api/datadog"
    	"github.com/DataDog/datadog-api-client-go/v2/api/datadogV2"
    )
    
    func main() {
    	body := datadogV2.AttachJiraIssueRequest{
    		Data: &datadogV2.AttachJiraIssueRequestData{
    			Attributes: &datadogV2.AttachJiraIssueRequestDataAttributes{
    				JiraIssueUrl: "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
    			},
    			Relationships: &datadogV2.AttachJiraIssueRequestDataRelationships{
    				Findings: datadogV2.Findings{
    					Data: []datadogV2.FindingData{
    						{
    							Id:   "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
    							Type: datadogV2.FINDINGDATATYPE_FINDINGS,
    						},
    					},
    				},
    				Project: datadogV2.CaseManagementProject{
    					Data: datadogV2.CaseManagementProjectData{
    						Id:   "959a6f71-bac8-4027-b1d3-2264f569296f",
    						Type: datadogV2.CASEMANAGEMENTPROJECTDATATYPE_PROJECTS,
    					},
    				},
    			},
    			Type: datadogV2.JIRAISSUESDATATYPE_JIRA_ISSUES,
    		},
    	}
    	ctx := datadog.NewDefaultContext(context.Background())
    	configuration := datadog.NewConfiguration()
    	apiClient := datadog.NewAPIClient(configuration)
    	api := datadogV2.NewSecurityMonitoringApi(apiClient)
    	resp, r, err := api.AttachJiraIssue(ctx, body)
    
    	if err != nil {
    		fmt.Fprintf(os.Stderr, "Error when calling `SecurityMonitoringApi.AttachJiraIssue`: %v\n", err)
    		fmt.Fprintf(os.Stderr, "Full HTTP response: %v\n", r)
    	}
    
    	responseContent, _ := json.MarshalIndent(resp, "", "  ")
    	fmt.Fprintf(os.Stdout, "Response from `SecurityMonitoringApi.AttachJiraIssue`:\n%s\n", responseContent)
    }
    
    // Attach security findings to a Jira issue returns "OK" response
    
    package main
    
    import (
    	"context"
    	"encoding/json"
    	"fmt"
    	"os"
    
    	"github.com/DataDog/datadog-api-client-go/v2/api/datadog"
    	"github.com/DataDog/datadog-api-client-go/v2/api/datadogV2"
    )
    
    func main() {
    	body := datadogV2.AttachJiraIssueRequest{
    		Data: &datadogV2.AttachJiraIssueRequestData{
    			Attributes: &datadogV2.AttachJiraIssueRequestDataAttributes{
    				JiraIssueUrl: "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
    			},
    			Relationships: &datadogV2.AttachJiraIssueRequestDataRelationships{
    				Findings: datadogV2.Findings{
    					Data: []datadogV2.FindingData{
    						{
    							Id:   "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
    							Type: datadogV2.FINDINGDATATYPE_FINDINGS,
    						},
    						{
    							Id:   "MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=",
    							Type: datadogV2.FINDINGDATATYPE_FINDINGS,
    						},
    					},
    				},
    				Project: datadogV2.CaseManagementProject{
    					Data: datadogV2.CaseManagementProjectData{
    						Id:   "959a6f71-bac8-4027-b1d3-2264f569296f",
    						Type: datadogV2.CASEMANAGEMENTPROJECTDATATYPE_PROJECTS,
    					},
    				},
    			},
    			Type: datadogV2.JIRAISSUESDATATYPE_JIRA_ISSUES,
    		},
    	}
    	ctx := datadog.NewDefaultContext(context.Background())
    	configuration := datadog.NewConfiguration()
    	apiClient := datadog.NewAPIClient(configuration)
    	api := datadogV2.NewSecurityMonitoringApi(apiClient)
    	resp, r, err := api.AttachJiraIssue(ctx, body)
    
    	if err != nil {
    		fmt.Fprintf(os.Stderr, "Error when calling `SecurityMonitoringApi.AttachJiraIssue`: %v\n", err)
    		fmt.Fprintf(os.Stderr, "Full HTTP response: %v\n", r)
    	}
    
    	responseContent, _ := json.MarshalIndent(resp, "", "  ")
    	fmt.Fprintf(os.Stdout, "Response from `SecurityMonitoringApi.AttachJiraIssue`:\n%s\n", responseContent)
    }
    

    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"
    // Attach security finding to a Jira issue returns "OK" response
    
    import com.datadog.api.client.ApiClient;
    import com.datadog.api.client.ApiException;
    import com.datadog.api.client.v2.api.SecurityMonitoringApi;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequest;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequestData;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequestDataAttributes;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequestDataRelationships;
    import com.datadog.api.client.v2.model.CaseManagementProject;
    import com.datadog.api.client.v2.model.CaseManagementProjectData;
    import com.datadog.api.client.v2.model.CaseManagementProjectDataType;
    import com.datadog.api.client.v2.model.FindingCaseResponse;
    import com.datadog.api.client.v2.model.FindingData;
    import com.datadog.api.client.v2.model.FindingDataType;
    import com.datadog.api.client.v2.model.Findings;
    import com.datadog.api.client.v2.model.JiraIssuesDataType;
    import java.util.Collections;
    
    public class Example {
      public static void main(String[] args) {
        ApiClient defaultClient = ApiClient.getDefaultApiClient();
        SecurityMonitoringApi apiInstance = new SecurityMonitoringApi(defaultClient);
    
        AttachJiraIssueRequest body =
            new AttachJiraIssueRequest()
                .data(
                    new AttachJiraIssueRequestData()
                        .attributes(
                            new AttachJiraIssueRequestDataAttributes()
                                .jiraIssueUrl(
                                    "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476"))
                        .relationships(
                            new AttachJiraIssueRequestDataRelationships()
                                .findings(
                                    new Findings()
                                        .data(
                                            Collections.singletonList(
                                                new FindingData()
                                                    .id(
                                                        "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=")
                                                    .type(FindingDataType.FINDINGS))))
                                .project(
                                    new CaseManagementProject()
                                        .data(
                                            new CaseManagementProjectData()
                                                .id("959a6f71-bac8-4027-b1d3-2264f569296f")
                                                .type(CaseManagementProjectDataType.PROJECTS))))
                        .type(JiraIssuesDataType.JIRA_ISSUES));
    
        try {
          FindingCaseResponse result = apiInstance.attachJiraIssue(body);
          System.out.println(result);
        } catch (ApiException e) {
          System.err.println("Exception when calling SecurityMonitoringApi#attachJiraIssue");
          System.err.println("Status code: " + e.getCode());
          System.err.println("Reason: " + e.getResponseBody());
          System.err.println("Response headers: " + e.getResponseHeaders());
          e.printStackTrace();
        }
      }
    }
    
    // Attach security findings to a Jira issue returns "OK" response
    
    import com.datadog.api.client.ApiClient;
    import com.datadog.api.client.ApiException;
    import com.datadog.api.client.v2.api.SecurityMonitoringApi;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequest;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequestData;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequestDataAttributes;
    import com.datadog.api.client.v2.model.AttachJiraIssueRequestDataRelationships;
    import com.datadog.api.client.v2.model.CaseManagementProject;
    import com.datadog.api.client.v2.model.CaseManagementProjectData;
    import com.datadog.api.client.v2.model.CaseManagementProjectDataType;
    import com.datadog.api.client.v2.model.FindingCaseResponse;
    import com.datadog.api.client.v2.model.FindingData;
    import com.datadog.api.client.v2.model.FindingDataType;
    import com.datadog.api.client.v2.model.Findings;
    import com.datadog.api.client.v2.model.JiraIssuesDataType;
    import java.util.Arrays;
    
    public class Example {
      public static void main(String[] args) {
        ApiClient defaultClient = ApiClient.getDefaultApiClient();
        SecurityMonitoringApi apiInstance = new SecurityMonitoringApi(defaultClient);
    
        AttachJiraIssueRequest body =
            new AttachJiraIssueRequest()
                .data(
                    new AttachJiraIssueRequestData()
                        .attributes(
                            new AttachJiraIssueRequestDataAttributes()
                                .jiraIssueUrl(
                                    "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476"))
                        .relationships(
                            new AttachJiraIssueRequestDataRelationships()
                                .findings(
                                    new Findings()
                                        .data(
                                            Arrays.asList(
                                                new FindingData()
                                                    .id(
                                                        "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=")
                                                    .type(FindingDataType.FINDINGS),
                                                new FindingData()
                                                    .id(
                                                        "MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=")
                                                    .type(FindingDataType.FINDINGS))))
                                .project(
                                    new CaseManagementProject()
                                        .data(
                                            new CaseManagementProjectData()
                                                .id("959a6f71-bac8-4027-b1d3-2264f569296f")
                                                .type(CaseManagementProjectDataType.PROJECTS))))
                        .type(JiraIssuesDataType.JIRA_ISSUES));
    
        try {
          FindingCaseResponse result = apiInstance.attachJiraIssue(body);
          System.out.println(result);
        } catch (ApiException e) {
          System.err.println("Exception when calling SecurityMonitoringApi#attachJiraIssue");
          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"
    """
    Attach security finding to a Jira issue returns "OK" response
    """
    
    from datadog_api_client import ApiClient, Configuration
    from datadog_api_client.v2.api.security_monitoring_api import SecurityMonitoringApi
    from datadog_api_client.v2.model.attach_jira_issue_request import AttachJiraIssueRequest
    from datadog_api_client.v2.model.attach_jira_issue_request_data import AttachJiraIssueRequestData
    from datadog_api_client.v2.model.attach_jira_issue_request_data_attributes import AttachJiraIssueRequestDataAttributes
    from datadog_api_client.v2.model.attach_jira_issue_request_data_relationships import (
        AttachJiraIssueRequestDataRelationships,
    )
    from datadog_api_client.v2.model.case_management_project import CaseManagementProject
    from datadog_api_client.v2.model.case_management_project_data import CaseManagementProjectData
    from datadog_api_client.v2.model.case_management_project_data_type import CaseManagementProjectDataType
    from datadog_api_client.v2.model.finding_data import FindingData
    from datadog_api_client.v2.model.finding_data_type import FindingDataType
    from datadog_api_client.v2.model.findings import Findings
    from datadog_api_client.v2.model.jira_issues_data_type import JiraIssuesDataType
    
    body = AttachJiraIssueRequest(
        data=AttachJiraIssueRequestData(
            attributes=AttachJiraIssueRequestDataAttributes(
                jira_issue_url="https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
            ),
            relationships=AttachJiraIssueRequestDataRelationships(
                findings=Findings(
                    data=[
                        FindingData(
                            id="OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                            type=FindingDataType.FINDINGS,
                        ),
                    ],
                ),
                project=CaseManagementProject(
                    data=CaseManagementProjectData(
                        id="959a6f71-bac8-4027-b1d3-2264f569296f",
                        type=CaseManagementProjectDataType.PROJECTS,
                    ),
                ),
            ),
            type=JiraIssuesDataType.JIRA_ISSUES,
        ),
    )
    
    configuration = Configuration()
    with ApiClient(configuration) as api_client:
        api_instance = SecurityMonitoringApi(api_client)
        response = api_instance.attach_jira_issue(body=body)
    
        print(response)
    
    """
    Attach security findings to a Jira issue returns "OK" response
    """
    
    from datadog_api_client import ApiClient, Configuration
    from datadog_api_client.v2.api.security_monitoring_api import SecurityMonitoringApi
    from datadog_api_client.v2.model.attach_jira_issue_request import AttachJiraIssueRequest
    from datadog_api_client.v2.model.attach_jira_issue_request_data import AttachJiraIssueRequestData
    from datadog_api_client.v2.model.attach_jira_issue_request_data_attributes import AttachJiraIssueRequestDataAttributes
    from datadog_api_client.v2.model.attach_jira_issue_request_data_relationships import (
        AttachJiraIssueRequestDataRelationships,
    )
    from datadog_api_client.v2.model.case_management_project import CaseManagementProject
    from datadog_api_client.v2.model.case_management_project_data import CaseManagementProjectData
    from datadog_api_client.v2.model.case_management_project_data_type import CaseManagementProjectDataType
    from datadog_api_client.v2.model.finding_data import FindingData
    from datadog_api_client.v2.model.finding_data_type import FindingDataType
    from datadog_api_client.v2.model.findings import Findings
    from datadog_api_client.v2.model.jira_issues_data_type import JiraIssuesDataType
    
    body = AttachJiraIssueRequest(
        data=AttachJiraIssueRequestData(
            attributes=AttachJiraIssueRequestDataAttributes(
                jira_issue_url="https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
            ),
            relationships=AttachJiraIssueRequestDataRelationships(
                findings=Findings(
                    data=[
                        FindingData(
                            id="OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                            type=FindingDataType.FINDINGS,
                        ),
                        FindingData(
                            id="MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=",
                            type=FindingDataType.FINDINGS,
                        ),
                    ],
                ),
                project=CaseManagementProject(
                    data=CaseManagementProjectData(
                        id="959a6f71-bac8-4027-b1d3-2264f569296f",
                        type=CaseManagementProjectDataType.PROJECTS,
                    ),
                ),
            ),
            type=JiraIssuesDataType.JIRA_ISSUES,
        ),
    )
    
    configuration = Configuration()
    with ApiClient(configuration) as api_client:
        api_instance = SecurityMonitoringApi(api_client)
        response = api_instance.attach_jira_issue(body=body)
    
        print(response)
    

    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"
    # Attach security finding to a Jira issue returns "OK" response
    
    require "datadog_api_client"
    api_instance = DatadogAPIClient::V2::SecurityMonitoringAPI.new
    
    body = DatadogAPIClient::V2::AttachJiraIssueRequest.new({
      data: DatadogAPIClient::V2::AttachJiraIssueRequestData.new({
        attributes: DatadogAPIClient::V2::AttachJiraIssueRequestDataAttributes.new({
          jira_issue_url: "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
        }),
        relationships: DatadogAPIClient::V2::AttachJiraIssueRequestDataRelationships.new({
          findings: DatadogAPIClient::V2::Findings.new({
            data: [
              DatadogAPIClient::V2::FindingData.new({
                id: "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                type: DatadogAPIClient::V2::FindingDataType::FINDINGS,
              }),
            ],
          }),
          project: DatadogAPIClient::V2::CaseManagementProject.new({
            data: DatadogAPIClient::V2::CaseManagementProjectData.new({
              id: "959a6f71-bac8-4027-b1d3-2264f569296f",
              type: DatadogAPIClient::V2::CaseManagementProjectDataType::PROJECTS,
            }),
          }),
        }),
        type: DatadogAPIClient::V2::JiraIssuesDataType::JIRA_ISSUES,
      }),
    })
    p api_instance.attach_jira_issue(body)
    
    # Attach security findings to a Jira issue returns "OK" response
    
    require "datadog_api_client"
    api_instance = DatadogAPIClient::V2::SecurityMonitoringAPI.new
    
    body = DatadogAPIClient::V2::AttachJiraIssueRequest.new({
      data: DatadogAPIClient::V2::AttachJiraIssueRequestData.new({
        attributes: DatadogAPIClient::V2::AttachJiraIssueRequestDataAttributes.new({
          jira_issue_url: "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
        }),
        relationships: DatadogAPIClient::V2::AttachJiraIssueRequestDataRelationships.new({
          findings: DatadogAPIClient::V2::Findings.new({
            data: [
              DatadogAPIClient::V2::FindingData.new({
                id: "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                type: DatadogAPIClient::V2::FindingDataType::FINDINGS,
              }),
              DatadogAPIClient::V2::FindingData.new({
                id: "MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=",
                type: DatadogAPIClient::V2::FindingDataType::FINDINGS,
              }),
            ],
          }),
          project: DatadogAPIClient::V2::CaseManagementProject.new({
            data: DatadogAPIClient::V2::CaseManagementProjectData.new({
              id: "959a6f71-bac8-4027-b1d3-2264f569296f",
              type: DatadogAPIClient::V2::CaseManagementProjectDataType::PROJECTS,
            }),
          }),
        }),
        type: DatadogAPIClient::V2::JiraIssuesDataType::JIRA_ISSUES,
      }),
    })
    p api_instance.attach_jira_issue(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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" rb "example.rb"
    // Attach security finding to a Jira issue returns "OK" response
    use datadog_api_client::datadog;
    use datadog_api_client::datadogV2::api_security_monitoring::SecurityMonitoringAPI;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequest;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequestData;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequestDataAttributes;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequestDataRelationships;
    use datadog_api_client::datadogV2::model::CaseManagementProject;
    use datadog_api_client::datadogV2::model::CaseManagementProjectData;
    use datadog_api_client::datadogV2::model::CaseManagementProjectDataType;
    use datadog_api_client::datadogV2::model::FindingData;
    use datadog_api_client::datadogV2::model::FindingDataType;
    use datadog_api_client::datadogV2::model::Findings;
    use datadog_api_client::datadogV2::model::JiraIssuesDataType;
    
    #[tokio::main]
    async fn main() {
        let body =
            AttachJiraIssueRequest
            ::new().data(
                AttachJiraIssueRequestData::new(JiraIssuesDataType::JIRA_ISSUES)
                    .attributes(
                        AttachJiraIssueRequestDataAttributes::new(
                            "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476".to_string(),
                        ),
                    )
                    .relationships(
                        AttachJiraIssueRequestDataRelationships::new(
                            Findings
                            ::new().data(
                                vec![
                                    FindingData::new(
                                        "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=".to_string(),
                                        FindingDataType::FINDINGS,
                                    )
                                ],
                            ),
                            CaseManagementProject::new(
                                CaseManagementProjectData::new(
                                    "959a6f71-bac8-4027-b1d3-2264f569296f".to_string(),
                                    CaseManagementProjectDataType::PROJECTS,
                                ),
                            ),
                        ),
                    ),
            );
        let configuration = datadog::Configuration::new();
        let api = SecurityMonitoringAPI::with_config(configuration);
        let resp = api.attach_jira_issue(body).await;
        if let Ok(value) = resp {
            println!("{:#?}", value);
        } else {
            println!("{:#?}", resp.unwrap_err());
        }
    }
    
    // Attach security findings to a Jira issue returns "OK" response
    use datadog_api_client::datadog;
    use datadog_api_client::datadogV2::api_security_monitoring::SecurityMonitoringAPI;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequest;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequestData;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequestDataAttributes;
    use datadog_api_client::datadogV2::model::AttachJiraIssueRequestDataRelationships;
    use datadog_api_client::datadogV2::model::CaseManagementProject;
    use datadog_api_client::datadogV2::model::CaseManagementProjectData;
    use datadog_api_client::datadogV2::model::CaseManagementProjectDataType;
    use datadog_api_client::datadogV2::model::FindingData;
    use datadog_api_client::datadogV2::model::FindingDataType;
    use datadog_api_client::datadogV2::model::Findings;
    use datadog_api_client::datadogV2::model::JiraIssuesDataType;
    
    #[tokio::main]
    async fn main() {
        let body =
            AttachJiraIssueRequest
            ::new().data(
                AttachJiraIssueRequestData::new(JiraIssuesDataType::JIRA_ISSUES)
                    .attributes(
                        AttachJiraIssueRequestDataAttributes::new(
                            "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476".to_string(),
                        ),
                    )
                    .relationships(
                        AttachJiraIssueRequestDataRelationships::new(
                            Findings
                            ::new().data(
                                vec![
                                    FindingData::new(
                                        "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=".to_string(),
                                        FindingDataType::FINDINGS,
                                    ),
                                    FindingData::new(
                                        "MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=".to_string(),
                                        FindingDataType::FINDINGS,
                                    )
                                ],
                            ),
                            CaseManagementProject::new(
                                CaseManagementProjectData::new(
                                    "959a6f71-bac8-4027-b1d3-2264f569296f".to_string(),
                                    CaseManagementProjectDataType::PROJECTS,
                                ),
                            ),
                        ),
                    ),
            );
        let configuration = datadog::Configuration::new();
        let api = SecurityMonitoringAPI::with_config(configuration);
        let resp = api.attach_jira_issue(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="<DD_API_KEY>" DD_APP_KEY="<DD_APP_KEY>" cargo run
    /**
     * Attach security finding to a Jira issue returns "OK" response
     */
    
    import { client, v2 } from "@datadog/datadog-api-client";
    
    const configuration = client.createConfiguration();
    const apiInstance = new v2.SecurityMonitoringApi(configuration);
    
    const params: v2.SecurityMonitoringApiAttachJiraIssueRequest = {
      body: {
        data: {
          attributes: {
            jiraIssueUrl:
              "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
          },
          relationships: {
            findings: {
              data: [
                {
                  id: "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                  type: "findings",
                },
              ],
            },
            project: {
              data: {
                id: "959a6f71-bac8-4027-b1d3-2264f569296f",
                type: "projects",
              },
            },
          },
          type: "jira_issues",
        },
      },
    };
    
    apiInstance
      .attachJiraIssue(params)
      .then((data: v2.FindingCaseResponse) => {
        console.log(
          "API called successfully. Returned data: " + JSON.stringify(data)
        );
      })
      .catch((error: any) => console.error(error));
    
    /**
     * Attach security findings to a Jira issue returns "OK" response
     */
    
    import { client, v2 } from "@datadog/datadog-api-client";
    
    const configuration = client.createConfiguration();
    const apiInstance = new v2.SecurityMonitoringApi(configuration);
    
    const params: v2.SecurityMonitoringApiAttachJiraIssueRequest = {
      body: {
        data: {
          attributes: {
            jiraIssueUrl:
              "https://datadoghq-sandbox-538.atlassian.net/browse/CSMSEC-105476",
          },
          relationships: {
            findings: {
              data: [
                {
                  id: "OTQ3NjJkMmYwMTIzMzMxNTc1Y2Q4MTA5NWU0NTBmMDl-ZjE3NjMxZWVkYzBjZGI1NDY2NWY2OGQxZDk4MDY4MmI=",
                  type: "findings",
                },
                {
                  id: "MTNjN2ZmYWMzMDIxYmU1ZDFiZDRjNWUwN2I1NzVmY2F-YTA3MzllMTUzNWM3NmEyZjdiNzEzOWM5YmViZTMzOGM=",
                  type: "findings",
                },
              ],
            },
            project: {
              data: {
                id: "959a6f71-bac8-4027-b1d3-2264f569296f",
                type: "projects",
              },
            },
          },
          type: "jira_issues",
        },
      },
    };
    
    apiInstance
      .attachJiraIssue(params)
      .then((data: v2.FindingCaseResponse) => {
        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"