Menu
Grafana Cloud

Reference

This page describes the entire API surface in detail.

Services

The Grafana Incident JSON/HTTP RPC API is made up of the following services:

  • ActivityService - ActivityService provides access to incident activity. You can post notes to the timeline, and query and update the individual timeline items.
  • FieldsService - FieldsService provides access to the Fields API, responsible for managing custom metadata fields.
  • IncidentsService - IncidentsService provides the ability to query, get, declare (create), update, and manage Incidents programmatically. You can also assign roles and update labels.
  • IntegrationService - IntegrationService is used to install Integrations, and wire up hooks.
  • KeyUpdatesService - KeyUpdatesService provides functionality to manage key updates for incidents. Key updates represent significant milestones or critical updates during an incident’s lifecycle.
  • RolesService - RolesService defines the interface for interacting with roles, providing CRUD operations and more features related to roles.
  • TasksService - TasksService provides methods for managing tasks relating to Incidents.
  • UsersService - UsersService provides services related to people in the system.

ActivityService

ActivityService provides access to incident activity. You can post notes to the timeline, and query and update the individual timeline items.

AddActivity

AddActivity posts an activity item to an Incident.

AddActivityRequest

  • incidentID - string - IncidentID is the unique identifier of the Incident. Is Required.
  • activityKind - string - options: "userNote" - ActivityKind is the type of activity this item represents. Is Required.
  • body - string - Body is a human readable description of the ActivityItem. URLs mentioned will be parsed and attached as context. Is Required. Maximum length: 65536.
  • fieldValues - object - FieldValues is an object of field values associated with the ActivityItem. The structure is determined by the ActivityKind.
  • eventTime - string - EventTime is the time when the event occurred. If empty, the current time is used. The string value format should follow RFC 3339.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.AddActivity" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"activityKind": "userNote",
	"body": "Some interesting insights from a third-party system",
	"eventTime": "2021-08-07T11:58:23Z",
	"fieldValues": {
		"something-else": true,
		"title": "new title"
	},
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	activityService := incident.NewActivityService(client)
	// make the request...
	addActivityResp, err := activityService.AddActivity(ctx, main.AddActivityRequest{
		IncidentID: "incident-123",
		ActivityKind: "userNote",
		Body: "Some interesting insights from a third-party system",
		FieldValues: {"something-else":true,"title":"new title"},
		EventTime: "2021-08-07T11:58:23Z",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("ActivityItem: %+v\n", addActivityResp.ActivityItem)
	log.Printf("Error: %+v\n", addActivityResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.AddActivity
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"activityKind": "userNote",
	"body": "Some interesting insights from a third-party system",
	"eventTime": "2021-08-07T11:58:23Z",
	"fieldValues": {
		"something-else": true,
		"title": "new title"
	},
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, ActivityService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const activityService = new ActivityService(client);

// AddActivity posts an activity item to an Incident.
const activityServiceResp = await activityService.addActivity({
	"activityKind": "userNote",
	"body": "Some interesting insights from a third-party system",
	"eventTime": "2021-08-07T11:58:23Z",
	"fieldValues": {
		"something-else": true,
		"title": "new title"
	},
	"incidentID": "incident-123"
});

if (!activityServiceResp.success) {
  // handle the error
  throw new Error(activityServiceResp.error);
}

// access the fields of the response
console.info({"activityItem", activityServiceResp.data.activityItem});

AddActivityResponse

A 200 response with an empty error field indicates that the request was successful.

  • activityItem - ActivityItem - ActivityItem is the newly created ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"activityItem": {
		"activityItemID": "activity-item-123",
		"activityKind": "incidentCreated",
		"attachments": [
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			},
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			}
		],
		"body": "The incident was created by user-123",
		"createdTime": "2021-08-07T11:58:23Z",
		"eventTime": "2021-08-07T11:58:23Z",
		"fieldValues": {
			"something-else": true,
			"title": "new title"
		},
		"immutable": true,
		"incidentID": "incident-123",
		"relevance": "low",
		"subjectUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"tags": [
			"important"
		],
		"url": "https://meet.google.com/my-incident-room",
		"user": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		}
	},
	"error": "something went wrong"
}

QueryActivity

QueryActivity gets a selection of activity items.

QueryActivityRequest

  • query - ActivityQuery - Query describes the query to make.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.QueryActivity" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"activityKind": [
			"incidentCreated"
		],
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "ASC",
		"tag": "important"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	activityService := incident.NewActivityService(client)
	// make the request...
	queryActivityResp, err := activityService.QueryActivity(ctx, main.QueryActivityRequest{
		Query: main.ActivityQuery{
			IncidentID: "incident-123",
			Limit: 10,
			Tag: "important",
			OrderDirection: "ASC",
			ActivityKind: ["incidentCreated"],
		},
		Cursor: main.Cursor{
			NextValue: "123e4567-e89b-12d3-a456-426614174000",
			HasMore: true,
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("ActivityItems: %+v\n", queryActivityResp.ActivityItems)
	log.Printf("Query: %+v\n", queryActivityResp.Query)
	log.Printf("Cursor: %+v\n", queryActivityResp.Cursor)
	log.Printf("Error: %+v\n", queryActivityResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.QueryActivity
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"activityKind": [
			"incidentCreated"
		],
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "ASC",
		"tag": "important"
	}
}
JavaScript
import { GrafanaIncidentClient, ActivityService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const activityService = new ActivityService(client);

// QueryActivity gets a selection of activity items.
const activityServiceResp = await activityService.queryActivity({
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"activityKind": [
			"incidentCreated"
		],
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "ASC",
		"tag": "important"
	}
});

if (!activityServiceResp.success) {
  // handle the error
  throw new Error(activityServiceResp.error);
}

// access the fields of the response
console.info({"activityItems", activityServiceResp.data.activityItems});
console.info({"query", activityServiceResp.data.query});
console.info({"cursor", activityServiceResp.data.cursor});

QueryActivityResponse

A 200 response with an empty error field indicates that the request was successful.

  • activityItems - array of ActivityItem - ActivityItems is the list of items.
  • query - ActivityQuery - Query is the query that was used to generate the response.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"activityItems": [
		{
			"activityItemID": "activity-item-123",
			"activityKind": "incidentCreated",
			"attachments": [
				{
					"attachedByUserID": "user-123",
					"attachmentErr": "file too large",
					"attachmentID": "attachment-123",
					"contentLength": 123456,
					"contentType": "image/jpeg",
					"deletedTime": "2019-01-01T00:00:00Z",
					"displayType": "list",
					"downloadURL": "https://somewhere.com/path/to/filename.jpg",
					"ext": ".jpg",
					"fileType": "image",
					"hasThumbnail": true,
					"path": "filename.jpg",
					"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
					"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
					"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
					"uploadTime": "2019-01-01T00:00:00Z",
					"useSourceURL": true
				},
				{
					"attachedByUserID": "user-123",
					"attachmentErr": "file too large",
					"attachmentID": "attachment-123",
					"contentLength": 123456,
					"contentType": "image/jpeg",
					"deletedTime": "2019-01-01T00:00:00Z",
					"displayType": "list",
					"downloadURL": "https://somewhere.com/path/to/filename.jpg",
					"ext": ".jpg",
					"fileType": "image",
					"hasThumbnail": true,
					"path": "filename.jpg",
					"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
					"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
					"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
					"uploadTime": "2019-01-01T00:00:00Z",
					"useSourceURL": true
				}
			],
			"body": "The incident was created by user-123",
			"createdTime": "2021-08-07T11:58:23Z",
			"eventTime": "2021-08-07T11:58:23Z",
			"fieldValues": {
				"something-else": true,
				"title": "new title"
			},
			"immutable": true,
			"incidentID": "incident-123",
			"relevance": "low",
			"subjectUser": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"tags": [
				"important"
			],
			"url": "https://meet.google.com/my-incident-room",
			"user": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			}
		},
		{
			"activityItemID": "activity-item-123",
			"activityKind": "incidentCreated",
			"attachments": [
				{
					"attachedByUserID": "user-123",
					"attachmentErr": "file too large",
					"attachmentID": "attachment-123",
					"contentLength": 123456,
					"contentType": "image/jpeg",
					"deletedTime": "2019-01-01T00:00:00Z",
					"displayType": "list",
					"downloadURL": "https://somewhere.com/path/to/filename.jpg",
					"ext": ".jpg",
					"fileType": "image",
					"hasThumbnail": true,
					"path": "filename.jpg",
					"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
					"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
					"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
					"uploadTime": "2019-01-01T00:00:00Z",
					"useSourceURL": true
				},
				{
					"attachedByUserID": "user-123",
					"attachmentErr": "file too large",
					"attachmentID": "attachment-123",
					"contentLength": 123456,
					"contentType": "image/jpeg",
					"deletedTime": "2019-01-01T00:00:00Z",
					"displayType": "list",
					"downloadURL": "https://somewhere.com/path/to/filename.jpg",
					"ext": ".jpg",
					"fileType": "image",
					"hasThumbnail": true,
					"path": "filename.jpg",
					"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
					"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
					"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
					"uploadTime": "2019-01-01T00:00:00Z",
					"useSourceURL": true
				}
			],
			"body": "The incident was created by user-123",
			"createdTime": "2021-08-07T11:58:23Z",
			"eventTime": "2021-08-07T11:58:23Z",
			"fieldValues": {
				"something-else": true,
				"title": "new title"
			},
			"immutable": true,
			"incidentID": "incident-123",
			"relevance": "low",
			"subjectUser": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"tags": [
				"important"
			],
			"url": "https://meet.google.com/my-incident-room",
			"user": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			}
		}
	],
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"error": "something went wrong",
	"query": {
		"activityKind": [
			"incidentCreated"
		],
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "ASC",
		"tag": "important"
	}
}

RemoveActivity

RemoveActivity removes an activity item.

RemoveActivityRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.RemoveActivity" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"activityItemID": "activity-item-123",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	activityService := incident.NewActivityService(client)
	// make the request...
	removeActivityResp, err := activityService.RemoveActivity(ctx, main.RemoveActivityRequest{
		IncidentID: "incident-123",
		ActivityItemID: "activity-item-123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("ActivityItem: %+v\n", removeActivityResp.ActivityItem)
	log.Printf("Error: %+v\n", removeActivityResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.RemoveActivity
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"activityItemID": "activity-item-123",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, ActivityService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const activityService = new ActivityService(client);

// RemoveActivity removes an activity item.
const activityServiceResp = await activityService.removeActivity({
	"activityItemID": "activity-item-123",
	"incidentID": "incident-123"
});

if (!activityServiceResp.success) {
  // handle the error
  throw new Error(activityServiceResp.error);
}

// access the fields of the response
console.info({"activityItem", activityServiceResp.data.activityItem});

RemoveActivityResponse

A 200 response with an empty error field indicates that the request was successful.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"activityItem": {
		"activityItemID": "activity-item-123",
		"activityKind": "incidentCreated",
		"attachments": [
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			},
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			}
		],
		"body": "The incident was created by user-123",
		"createdTime": "2021-08-07T11:58:23Z",
		"eventTime": "2021-08-07T11:58:23Z",
		"fieldValues": {
			"something-else": true,
			"title": "new title"
		},
		"immutable": true,
		"incidentID": "incident-123",
		"relevance": "low",
		"subjectUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"tags": [
			"important"
		],
		"url": "https://meet.google.com/my-incident-room",
		"user": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		}
	},
	"error": "something went wrong"
}

UpdateActivityBody

UpdateActivityBody updates the body of a specific activity item.

UpdateActivityBodyRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
  • body - string - Body is the new body to use for the given activity item Is Required. Maximum length: 65536.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.UpdateActivityBody" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"activityItemID": "activity-item-123",
	"body": "New contents",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	activityService := incident.NewActivityService(client)
	// make the request...
	updateActivityBodyResp, err := activityService.UpdateActivityBody(ctx, main.UpdateActivityBodyRequest{
		IncidentID: "incident-123",
		ActivityItemID: "activity-item-123",
		Body: "New contents",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("ActivityItem: %+v\n", updateActivityBodyResp.ActivityItem)
	log.Printf("Error: %+v\n", updateActivityBodyResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.UpdateActivityBody
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"activityItemID": "activity-item-123",
	"body": "New contents",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, ActivityService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const activityService = new ActivityService(client);

// UpdateActivityBody updates the body of a specific activity item.
const activityServiceResp = await activityService.updateActivityBody({
	"activityItemID": "activity-item-123",
	"body": "New contents",
	"incidentID": "incident-123"
});

if (!activityServiceResp.success) {
  // handle the error
  throw new Error(activityServiceResp.error);
}

// access the fields of the response
console.info({"activityItem", activityServiceResp.data.activityItem});

UpdateActivityBodyResponse

A 200 response with an empty error field indicates that the request was successful.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"activityItem": {
		"activityItemID": "activity-item-123",
		"activityKind": "incidentCreated",
		"attachments": [
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			},
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			}
		],
		"body": "The incident was created by user-123",
		"createdTime": "2021-08-07T11:58:23Z",
		"eventTime": "2021-08-07T11:58:23Z",
		"fieldValues": {
			"something-else": true,
			"title": "new title"
		},
		"immutable": true,
		"incidentID": "incident-123",
		"relevance": "low",
		"subjectUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"tags": [
			"important"
		],
		"url": "https://meet.google.com/my-incident-room",
		"user": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		}
	},
	"error": "something went wrong"
}

UpdateActivityEventTime

UpdateActivityEventTime updates the event time of a specific activity item.

UpdateActivityEventTimeRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
  • eventTime - string - EventTime is the time when the event occurred. If empty, the created time of the activity item is used. The string value format should follow RFC 3339.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.UpdateActivityEventTime" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"activityItemID": "activity-item-123",
	"eventTime": "2021-08-07T11:58:23Z",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	activityService := incident.NewActivityService(client)
	// make the request...
	updateActivityEventTimeResp, err := activityService.UpdateActivityEventTime(ctx, main.UpdateActivityEventTimeRequest{
		IncidentID: "incident-123",
		ActivityItemID: "activity-item-123",
		EventTime: "2021-08-07T11:58:23Z",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("ActivityItem: %+v\n", updateActivityEventTimeResp.ActivityItem)
	log.Printf("Error: %+v\n", updateActivityEventTimeResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.UpdateActivityEventTime
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"activityItemID": "activity-item-123",
	"eventTime": "2021-08-07T11:58:23Z",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, ActivityService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const activityService = new ActivityService(client);

// UpdateActivityEventTime updates the event time of a specific activity item.
const activityServiceResp = await activityService.updateActivityEventTime({
	"activityItemID": "activity-item-123",
	"eventTime": "2021-08-07T11:58:23Z",
	"incidentID": "incident-123"
});

if (!activityServiceResp.success) {
  // handle the error
  throw new Error(activityServiceResp.error);
}

// access the fields of the response
console.info({"activityItem", activityServiceResp.data.activityItem});

UpdateActivityEventTimeResponse

A 200 response with an empty error field indicates that the request was successful.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"activityItem": {
		"activityItemID": "activity-item-123",
		"activityKind": "incidentCreated",
		"attachments": [
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			},
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			}
		],
		"body": "The incident was created by user-123",
		"createdTime": "2021-08-07T11:58:23Z",
		"eventTime": "2021-08-07T11:58:23Z",
		"fieldValues": {
			"something-else": true,
			"title": "new title"
		},
		"immutable": true,
		"incidentID": "incident-123",
		"relevance": "low",
		"subjectUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"tags": [
			"important"
		],
		"url": "https://meet.google.com/my-incident-room",
		"user": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		}
	},
	"error": "something went wrong"
}

UpdateActivityRelevance

UpdateActivityRelevance sets the relevance of an activity item.

UpdateActivityRelevanceRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
  • relevance - string - options: "automatic" "archive" "low" "normal" "high" - Relevance is the preferred relevance of the activity item. if set to ‘automatic’ (the default), the relevance will be guessed automatically. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.UpdateActivityRelevance" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"activityItemID": "activity-item-123",
	"incidentID": "incident-123",
	"relevance": "low"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	activityService := incident.NewActivityService(client)
	// make the request...
	updateActivityRelevanceResp, err := activityService.UpdateActivityRelevance(ctx, main.UpdateActivityRelevanceRequest{
		IncidentID: "incident-123",
		ActivityItemID: "activity-item-123",
		Relevance: "low",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("ActivityItem: %+v\n", updateActivityRelevanceResp.ActivityItem)
	log.Printf("Error: %+v\n", updateActivityRelevanceResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/ActivityService.UpdateActivityRelevance
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"activityItemID": "activity-item-123",
	"incidentID": "incident-123",
	"relevance": "low"
}
JavaScript
import { GrafanaIncidentClient, ActivityService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const activityService = new ActivityService(client);

// UpdateActivityRelevance sets the relevance of an activity item.
const activityServiceResp = await activityService.updateActivityRelevance({
	"activityItemID": "activity-item-123",
	"incidentID": "incident-123",
	"relevance": "low"
});

if (!activityServiceResp.success) {
  // handle the error
  throw new Error(activityServiceResp.error);
}

// access the fields of the response
console.info({"activityItem", activityServiceResp.data.activityItem});

UpdateActivityRelevanceResponse

A 200 response with an empty error field indicates that the request was successful.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"activityItem": {
		"activityItemID": "activity-item-123",
		"activityKind": "incidentCreated",
		"attachments": [
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			},
			{
				"attachedByUserID": "user-123",
				"attachmentErr": "file too large",
				"attachmentID": "attachment-123",
				"contentLength": 123456,
				"contentType": "image/jpeg",
				"deletedTime": "2019-01-01T00:00:00Z",
				"displayType": "list",
				"downloadURL": "https://somewhere.com/path/to/filename.jpg",
				"ext": ".jpg",
				"fileType": "image",
				"hasThumbnail": true,
				"path": "filename.jpg",
				"sHA512": "327232b67c88cba87c0a85a32bb192df527c21854d6515144d691f8cf1554f8e9969eed443b85e00d5ea21628c0ca4b6bbc9f26c837815fad6e9b3881cbb5cfd",
				"sourceURL": "https://somewhere-like-slack.com/path/to/filename.jpg",
				"thumbnailURL": "https://somewhere.com/path/to/thumbnail.jpg",
				"uploadTime": "2019-01-01T00:00:00Z",
				"useSourceURL": true
			}
		],
		"body": "The incident was created by user-123",
		"createdTime": "2021-08-07T11:58:23Z",
		"eventTime": "2021-08-07T11:58:23Z",
		"fieldValues": {
			"something-else": true,
			"title": "new title"
		},
		"immutable": true,
		"incidentID": "incident-123",
		"relevance": "low",
		"subjectUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"tags": [
			"important"
		],
		"url": "https://meet.google.com/my-incident-room",
		"user": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		}
	},
	"error": "something went wrong"
}

FieldsService

FieldsService provides access to the Fields API, responsible for managing custom metadata fields.

AddField

AddField adds a new field to the org.

AddFieldRequest

curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddField" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	addFieldResp, err := fieldsService.AddField(ctx, main.AddFieldRequest{
		Field: main.CustomMetadataField{
			UUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			Name: "field name",
			Slug: "field_slug",
			Color: "#FF00FF",
			Icon: "fa-alt",
			Description: "field description",
			Type: "string",
			Required: "true",
			Immutable: "false",
			DomainName: "string",
			Selectoptions: main.CustomMetadataFieldSelectOption{
				UUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				Value: "value",
				Label: "My field option name",
				Color: "#000000",
				Icon: "file-alt",
				Description: "This label represents a new option",
				Source: "incident",
				ExternalID: "1",
			},
			Source: "incident",
			ExternalID: "1",
			Archived: "false",
			Version: "1",
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Field: %+v\n", addFieldResp.Field)
	log.Printf("Error: %+v\n", addFieldResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddField
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// AddField adds a new field to the org.
const fieldsServiceResp = await fieldsService.addField({
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"field", fieldsServiceResp.data.field});

AddFieldResponse

A 200 response with an empty error field indicates that the request was successful.

  • field - CustomMetadataField - Field is the field that was added.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}

AddFieldSelectOption

AddFieldSelectOption adds a field select option.

AddFieldSelectOptionRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
  • fieldSelectOption - CustomMetadataFieldSelectOption - FieldSelectOption is the new field select option.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddFieldSelectOption" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"fieldSelectOption": {
		"color": "#000000",
		"description": "This label represents a new option",
		"externalID": "1",
		"icon": "file-alt",
		"label": "My field option name",
		"source": "incident",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"value": "value"
	},
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	addFieldSelectOptionResp, err := fieldsService.AddFieldSelectOption(ctx, main.AddFieldSelectOptionRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		FieldSelectOption: main.CustomMetadataFieldSelectOption{
			UUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			Value: "value",
			Label: "My field option name",
			Color: "#000000",
			Icon: "file-alt",
			Description: "This label represents a new option",
			Source: "incident",
			ExternalID: "1",
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("FieldSelectOptionUUID: %+v\n", addFieldSelectOptionResp.FieldSelectOptionUUID)
	log.Printf("Error: %+v\n", addFieldSelectOptionResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddFieldSelectOption
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"fieldSelectOption": {
		"color": "#000000",
		"description": "This label represents a new option",
		"externalID": "1",
		"icon": "file-alt",
		"label": "My field option name",
		"source": "incident",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"value": "value"
	},
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// AddFieldSelectOption adds a field select option.
const fieldsServiceResp = await fieldsService.addFieldSelectOption({
	"fieldSelectOption": {
		"color": "#000000",
		"description": "This label represents a new option",
		"externalID": "1",
		"icon": "file-alt",
		"label": "My field option name",
		"source": "incident",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"value": "value"
	},
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"fieldSelectOptionUUID", fieldsServiceResp.data.fieldSelectOptionUUID});

AddFieldSelectOptionResponse

A 200 response with an empty error field indicates that the request was successful.

  • fieldSelectOptionUUID - string - FieldSelectOptionUUID is the UUID of the field select option that was added.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"fieldSelectOptionUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f91333"
}

AddLabelKey

AddLabelKey creates a field with the label domain.

AddLabelKeyRequest

  • key - string - Key is the label key.
  • description - string - Description is a short explanation of the label.
  • colorHex - string - Color is the CSS hex color of the label. Labels show up in both light and dark modes, and this should be taken into consideration when selecting a color.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddLabelKey" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"colorHex": "#ff0000",
	"description": "Service name.",
	"key": "service_name"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	addLabelKeyResp, err := fieldsService.AddLabelKey(ctx, main.AddLabelKeyRequest{
		Key: "service_name",
		Description: "Service name.",
		ColorHex: "#ff0000",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Field: %+v\n", addLabelKeyResp.Field)
	log.Printf("Error: %+v\n", addLabelKeyResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddLabelKey
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"colorHex": "#ff0000",
	"description": "Service name.",
	"key": "service_name"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// AddLabelKey creates a field with the label domain.
const fieldsServiceResp = await fieldsService.addLabelKey({
	"colorHex": "#ff0000",
	"description": "Service name.",
	"key": "service_name"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"field", fieldsServiceResp.data.field});

AddLabelKeyResponse

A 200 response with an empty error field indicates that the request was successful.

  • field - CustomMetadataField - Field is the field that was added.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}

AddLabelValue

AddLabelValue adds a label value to a given label key.

AddLabelValueRequest

  • key - string - Key is the label key.
  • value - string - Value is the label value.
  • description - string - Description is a short explanation of the label value.
  • colorHex - string - Color is the CSS hex color of the label value. Labels show up in both light and dark modes, and this should be taken into consideration when selecting a color.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddLabelValue" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"colorHex": "#ff0000",
	"description": "Login service.",
	"key": "service_name",
	"value": "login"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	addLabelValueResp, err := fieldsService.AddLabelValue(ctx, main.AddLabelValueRequest{
		Key: "service_name",
		Value: "login",
		Description: "Login service.",
		ColorHex: "#ff0000",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Field: %+v\n", addLabelValueResp.Field)
	log.Printf("Error: %+v\n", addLabelValueResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.AddLabelValue
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"colorHex": "#ff0000",
	"description": "Login service.",
	"key": "service_name",
	"value": "login"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// AddLabelValue adds a label value to a given label key.
const fieldsServiceResp = await fieldsService.addLabelValue({
	"colorHex": "#ff0000",
	"description": "Login service.",
	"key": "service_name",
	"value": "login"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"field", fieldsServiceResp.data.field});

AddLabelValueResponse

A 200 response with an empty error field indicates that the request was successful.

  • field - CustomMetadataField - Field is the field that was updated.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}

ArchiveField

ArchiveField archives a field.

ArchiveFieldRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.ArchiveField" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	archiveFieldResp, err := fieldsService.ArchiveField(ctx, main.ArchiveFieldRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", archiveFieldResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.ArchiveField
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const fieldsService = new FieldsService(client);

// ArchiveField archives a field.
const fieldsServiceResp = await fieldsService.archiveField({
  fieldUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response

ArchiveFieldResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

DeleteField

DeleteField deletes a field.

DeleteFieldRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.DeleteField" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	deleteFieldResp, err := fieldsService.DeleteField(ctx, main.DeleteFieldRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", deleteFieldResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.DeleteField
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const fieldsService = new FieldsService(client);

// DeleteField deletes a field.
const fieldsServiceResp = await fieldsService.deleteField({
  fieldUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response

DeleteFieldResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

DeleteFieldSelectOption

DeleteFieldSelectOption deletes a field select option.

DeleteFieldSelectOptionRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
  • selectOptionUUID - string - SelectOptionUUID is the UUID of the field select option to delete. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.DeleteFieldSelectOption" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"selectOptionUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	deleteFieldSelectOptionResp, err := fieldsService.DeleteFieldSelectOption(ctx, main.DeleteFieldSelectOptionRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		SelectOptionUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", deleteFieldSelectOptionResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.DeleteFieldSelectOption
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"selectOptionUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const fieldsService = new FieldsService(client);

// DeleteFieldSelectOption deletes a field select option.
const fieldsServiceResp = await fieldsService.deleteFieldSelectOption({
  fieldUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
  selectOptionUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response

DeleteFieldSelectOptionResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

GetField

GetField returns fields in the org.

GetFieldRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.GetField" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	getFieldResp, err := fieldsService.GetField(ctx, main.GetFieldRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Field: %+v\n", getFieldResp.Field)
	log.Printf("Error: %+v\n", getFieldResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.GetField
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// GetField returns fields in the org.
const fieldsServiceResp = await fieldsService.getField({
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"field", fieldsServiceResp.data.field});

GetFieldResponse

A 200 response with an empty error field indicates that the request was successful.

  • field - CustomMetadataField - Field is the requested field.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}

GetFieldValues

GetFieldValues gets the key->value linked to a target.

GetFieldValuesRequest

  • targetKind - string - options: "incident" - TargetKind is the kind of the target to record the field value for. Is Required.
  • targetID - string - TargetID is the ID of the target to record the field value for. Is Required.
  • domainName - string - DomainName, if provided, will filter the results to the specified domain.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.GetFieldValues" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"domainName": "labels",
	"targetID": "targetID",
	"targetKind": "incident"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	getFieldValuesResp, err := fieldsService.GetFieldValues(ctx, main.GetFieldValuesRequest{
		TargetKind: "incident",
		TargetID: "targetID",
		DomainName: "labels",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("FieldValues: %+v\n", getFieldValuesResp.FieldValues)
	log.Printf("Error: %+v\n", getFieldValuesResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.GetFieldValues
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"domainName": "labels",
	"targetID": "targetID",
	"targetKind": "incident"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// GetFieldValues gets the key->value linked to a target.
const fieldsServiceResp = await fieldsService.getFieldValues({
	"domainName": "labels",
	"targetID": "targetID",
	"targetKind": "incident"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"fieldValues", fieldsServiceResp.data.fieldValues});

GetFieldValuesResponse

A 200 response with an empty error field indicates that the request was successful.

  • fieldValues - array of FieldValue - FieldValues is a list of field->value pairs.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"fieldValues": [
		{
			"field": {
				"archived": "false",
				"color": "#FF00FF",
				"description": "field description",
				"domainName": "string",
				"externalID": "1",
				"icon": "fa-alt",
				"immutable": "false",
				"name": "field name",
				"required": "true",
				"selectoptions": [
					{
						"color": "#000000",
						"description": "This label represents a new option",
						"externalID": "1",
						"icon": "file-alt",
						"label": "My field option name",
						"source": "incident",
						"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
						"value": "value"
					},
					{
						"color": "#000000",
						"description": "This label represents a new option",
						"externalID": "1",
						"icon": "file-alt",
						"label": "My field option name",
						"source": "incident",
						"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
						"value": "value"
					}
				],
				"slug": "field_slug",
				"source": "incident",
				"type": "string",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"version": "1"
			},
			"value": "value"
		},
		{
			"field": {
				"archived": "false",
				"color": "#FF00FF",
				"description": "field description",
				"domainName": "string",
				"externalID": "1",
				"icon": "fa-alt",
				"immutable": "false",
				"name": "field name",
				"required": "true",
				"selectoptions": [
					{
						"color": "#000000",
						"description": "This label represents a new option",
						"externalID": "1",
						"icon": "file-alt",
						"label": "My field option name",
						"source": "incident",
						"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
						"value": "value"
					},
					{
						"color": "#000000",
						"description": "This label represents a new option",
						"externalID": "1",
						"icon": "file-alt",
						"label": "My field option name",
						"source": "incident",
						"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
						"value": "value"
					}
				],
				"slug": "field_slug",
				"source": "incident",
				"type": "string",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"version": "1"
			},
			"value": "value"
		}
	]
}

GetFields

GetFields returns a list of all custom fields in the org.

GetFieldsRequest

  • domainName - string - DomainName, if provided, will filter the results to the specified domain.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.GetFields" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"domainName": "labels"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	getFieldsResp, err := fieldsService.GetFields(ctx, main.GetFieldsRequest{
		DomainName: "labels",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Fields: %+v\n", getFieldsResp.Fields)
	log.Printf("Error: %+v\n", getFieldsResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.GetFields
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"domainName": "labels"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// GetFields returns a list of all custom fields in the org.
const fieldsServiceResp = await fieldsService.getFields({
	"domainName": "labels"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"fields", fieldsServiceResp.data.fields});

GetFieldsResponse

A 200 response with an empty error field indicates that the request was successful.

  • fields - array of CustomMetadataField - Fields is the list of fields.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"fields": [
		{
			"archived": "false",
			"color": "#FF00FF",
			"description": "field description",
			"domainName": "string",
			"externalID": "1",
			"icon": "fa-alt",
			"immutable": "false",
			"name": "field name",
			"required": "true",
			"selectoptions": [
				{
					"color": "#000000",
					"description": "This label represents a new option",
					"externalID": "1",
					"icon": "file-alt",
					"label": "My field option name",
					"source": "incident",
					"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				},
				{
					"color": "#000000",
					"description": "This label represents a new option",
					"externalID": "1",
					"icon": "file-alt",
					"label": "My field option name",
					"source": "incident",
					"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				}
			],
			"slug": "field_slug",
			"source": "incident",
			"type": "string",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"version": "1"
		},
		{
			"archived": "false",
			"color": "#FF00FF",
			"description": "field description",
			"domainName": "string",
			"externalID": "1",
			"icon": "fa-alt",
			"immutable": "false",
			"name": "field name",
			"required": "true",
			"selectoptions": [
				{
					"color": "#000000",
					"description": "This label represents a new option",
					"externalID": "1",
					"icon": "file-alt",
					"label": "My field option name",
					"source": "incident",
					"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				},
				{
					"color": "#000000",
					"description": "This label represents a new option",
					"externalID": "1",
					"icon": "file-alt",
					"label": "My field option name",
					"source": "incident",
					"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				}
			],
			"slug": "field_slug",
			"source": "incident",
			"type": "string",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"version": "1"
		}
	]
}

UnarchiveField

UnarchiveField unarchives a field.

UnarchiveFieldRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.UnarchiveField" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	unarchiveFieldResp, err := fieldsService.UnarchiveField(ctx, main.UnarchiveFieldRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", unarchiveFieldResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.UnarchiveField
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const fieldsService = new FieldsService(client);

// UnarchiveField unarchives a field.
const fieldsServiceResp = await fieldsService.unarchiveField({
  fieldUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response

UnarchiveFieldResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

UpdateField

UpdateField updates a field.

UpdateFieldRequest

  • fieldUUID - string - FieldUUID is the UUID of the field.
  • name - string - Name is the name of the field.
  • slug - string - Slug is the slug of the field. Used for searching and referencing the field as a metric.
  • color - string - Color is the field color.
  • icon - string - Icon is the field icon.
  • description - string - Description is the description of the field.
  • required - boolean - Required is whether this field is required.
  • domainName - string - DomainName is single-select for which a field is valid/used.
  • immutable - boolean - Immutable indicates if the field can by modified by the user.
  • selectoptions - array of CustomMetadataFieldSelectOption - Selectoptions is the list of select options for the field. Only used for select fields.
  • version - number - Version is the field version. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.UpdateField" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"color": "#FF00FF",
	"description": "field description",
	"domainName": "labels",
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"icon": "fa-alt",
	"immutable": "false",
	"name": "field name",
	"required": "true",
	"selectoptions": [
		{
			"color": "#000000",
			"description": "This label represents a new option",
			"externalID": "1",
			"icon": "file-alt",
			"label": "My field option name",
			"source": "incident",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "value"
		},
		{
			"color": "#000000",
			"description": "This label represents a new option",
			"externalID": "1",
			"icon": "file-alt",
			"label": "My field option name",
			"source": "incident",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "value"
		}
	],
	"slug": "field_slug",
	"version": "1"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	updateFieldResp, err := fieldsService.UpdateField(ctx, main.UpdateFieldRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		Name: "field name",
		Slug: "field_slug",
		Color: "#FF00FF",
		Icon: "fa-alt",
		Description: "field description",
		Required: "true",
		DomainName: "labels",
		Immutable: "false",
		Selectoptions: main.CustomMetadataFieldSelectOption{
			UUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			Value: "value",
			Label: "My field option name",
			Color: "#000000",
			Icon: "file-alt",
			Description: "This label represents a new option",
			Source: "incident",
			ExternalID: "1",
		},
		Version: "1",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Field: %+v\n", updateFieldResp.Field)
	log.Printf("Error: %+v\n", updateFieldResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.UpdateField
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"color": "#FF00FF",
	"description": "field description",
	"domainName": "labels",
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"icon": "fa-alt",
	"immutable": "false",
	"name": "field name",
	"required": "true",
	"selectoptions": [
		{
			"color": "#000000",
			"description": "This label represents a new option",
			"externalID": "1",
			"icon": "file-alt",
			"label": "My field option name",
			"source": "incident",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "value"
		},
		{
			"color": "#000000",
			"description": "This label represents a new option",
			"externalID": "1",
			"icon": "file-alt",
			"label": "My field option name",
			"source": "incident",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "value"
		}
	],
	"slug": "field_slug",
	"version": "1"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const fieldsService = new FieldsService(client);

// UpdateField updates a field.
const fieldsServiceResp = await fieldsService.updateField({
	"color": "#FF00FF",
	"description": "field description",
	"domainName": "labels",
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"icon": "fa-alt",
	"immutable": "false",
	"name": "field name",
	"required": "true",
	"selectoptions": [
		{
			"color": "#000000",
			"description": "This label represents a new option",
			"externalID": "1",
			"icon": "file-alt",
			"label": "My field option name",
			"source": "incident",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "value"
		},
		{
			"color": "#000000",
			"description": "This label represents a new option",
			"externalID": "1",
			"icon": "file-alt",
			"label": "My field option name",
			"source": "incident",
			"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "value"
		}
	],
	"slug": "field_slug",
	"version": "1"
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response
console.info({"field", fieldsServiceResp.data.field});

UpdateFieldResponse

A 200 response with an empty error field indicates that the request was successful.

  • field - CustomMetadataField - Field is the field that was updated.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"field": {
		"archived": "false",
		"color": "#FF00FF",
		"description": "field description",
		"domainName": "string",
		"externalID": "1",
		"icon": "fa-alt",
		"immutable": "false",
		"name": "field name",
		"required": "true",
		"selectoptions": [
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			},
			{
				"color": "#000000",
				"description": "This label represents a new option",
				"externalID": "1",
				"icon": "file-alt",
				"label": "My field option name",
				"source": "incident",
				"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
				"value": "value"
			}
		],
		"slug": "field_slug",
		"source": "incident",
		"type": "string",
		"uuid": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		"version": "1"
	}
}

UpdateFieldSelectOption

UpdateFieldSelectOption updates a field select option.

UpdateFieldSelectOptionRequest

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
  • selectOptionUUID - string - SelectOptionUUID is the UUID of the field select option to delete. Is Required.
  • value - string - Value is the value of the select option.
  • label - string - Label is the label of the select option.
  • color - string - Color is the color of the select option.
  • icon - string - Icon is the icon of the select option.
  • description - string - Description is the textual description of the option.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.UpdateFieldSelectOption" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"color": "#000000",
	"description": "This label represents a new option",
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"icon": "file-alt",
	"label": "My field option name",
	"selectOptionUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"value": "value"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	fieldsService := incident.NewFieldsService(client)
	// make the request...
	updateFieldSelectOptionResp, err := fieldsService.UpdateFieldSelectOption(ctx, main.UpdateFieldSelectOptionRequest{
		FieldUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		SelectOptionUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		Value: "value",
		Label: "My field option name",
		Color: "#000000",
		Icon: "file-alt",
		Description: "This label represents a new option",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", updateFieldSelectOptionResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/FieldsService.UpdateFieldSelectOption
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"color": "#000000",
	"description": "This label represents a new option",
	"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"icon": "file-alt",
	"label": "My field option name",
	"selectOptionUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"value": "value"
}
JavaScript
import { GrafanaIncidentClient, FieldsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const fieldsService = new FieldsService(client);

// UpdateFieldSelectOption updates a field select option.
const fieldsServiceResp = await fieldsService.updateFieldSelectOption({
  color: '#000000',
  description: 'This label represents a new option',
  fieldUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
  icon: 'file-alt',
  label: 'My field option name',
  selectOptionUUID: '3fb1e5d7-3ef2-11ef-b731-deab26f9180f',
  value: 'value',
});

if (!fieldsServiceResp.success) {
  // handle the error
  throw new Error(fieldsServiceResp.error);
}

// access the fields of the response

UpdateFieldSelectOptionResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

IncidentsService

IncidentsService provides the ability to query, get, declare (create), update, and manage Incidents programmatically. You can also assign roles and update labels.

  • AddLabel - AddLabel adds a label to the Incident.
  • AssignLabel - AssignLabel assigns a key:value label to the incident
  • AssignLabelByUUID - AssignLabelByUUID assigns a keyUUID:valueUUID label to the incident
  • AssignRole - AssignRole assigns a role to a user.
  • CreateIncident - CreateIncident creates a new Incident.
  • GetIncident - GetIncident gets an existing Incident by ID.
  • GetIncidentMembership - GetIncidentMembership will return the full list of people involved in an incident
  • GetLabels - GetLabels get the labels from the incident.
  • QueryIncidentPreviews - QueryIncidentPreviews gets a list of Incident Previews.
  • QueryIncidents - QueryIncidents gets a list of Incidents. (Deprecated: use QueryIncidentPreviews instead.)
  • RemoveLabel - RemoveLabel removes a label from the Incident.
  • UnassignLabel - UnassignLabel unassigns a key:value label from the incident
  • UnassignLabelByUUID - UnassignLabelByUUID unassigns a keyUUID:valueUUID label from the incident
  • UnassignRole - UnassignRole removes a role assignment from a user.
  • UpdateIncidentEventTime - UpdateIncidentEventTime updates the start or end times of an Incident.
  • UpdateIncidentIsDrill - UpdateIncidentIsDrill changes whether an Incident is a drill or not.
  • UpdateSeverity - UpdateSeverity updates the severity of an Incident.
  • UpdateStatus - UpdateStatus updates the status of an Incident.
  • UpdateTitle - UpdateTitle updates the title of an Incident.

AddLabel

AddLabel adds a label to the Incident.

AddLabelRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • label - IncidentLabel - Label is the new label of the Incident.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AddLabel" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"label": {
		"colorHex": "#ff0000",
		"description": "Customers are affected by this incident.",
		"key": "service_name",
		"label": "customers-affected"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	addLabelResp, err := incidentsService.AddLabel(ctx, main.AddLabelRequest{
		IncidentID: "incident-123",
		Label: main.IncidentLabel{
			Key: "service_name",
			Label: "customers-affected",
			Description: "Customers are affected by this incident.",
			ColorHex: "#ff0000",
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", addLabelResp.Incident)
	log.Printf("Error: %+v\n", addLabelResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AddLabel
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"label": {
		"colorHex": "#ff0000",
		"description": "Customers are affected by this incident.",
		"key": "service_name",
		"label": "customers-affected"
	}
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// AddLabel adds a label to the Incident.
const incidentsServiceResp = await incidentsService.addLabel({
	"incidentID": "incident-123",
	"label": {
		"colorHex": "#ff0000",
		"description": "Customers are affected by this incident.",
		"key": "service_name",
		"label": "customers-affected"
	}
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

AddLabelResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

AssignLabel

AssignLabel assigns a key:value label to the incident

AssignLabelRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • key - string - Key is the label key. Is Required.
  • value - string - Value is the value of the label. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AssignLabel" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"key": "service_name",
	"value": "customers-affected"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	assignLabelResp, err := incidentsService.AssignLabel(ctx, main.AssignLabelRequest{
		IncidentID: "incident-123",
		Key: "service_name",
		Value: "customers-affected",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Labels: %+v\n", assignLabelResp.Labels)
	log.Printf("Error: %+v\n", assignLabelResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AssignLabel
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"key": "service_name",
	"value": "customers-affected"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// AssignLabel assigns a key:value label to the incident
const incidentsServiceResp = await incidentsService.assignLabel({
	"incidentID": "incident-123",
	"key": "service_name",
	"value": "customers-affected"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"labels", incidentsServiceResp.data.labels});

AssignLabelResponse

A 200 response with an empty error field indicates that the request was successful.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		}
	]
}

AssignLabelByUUID

AssignLabelByUUID assigns a keyUUID:valueUUID label to the incident

AssignLabelByUUIDRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • keyUUID - string - KeyUUID is the label key uuid. Is Required.
  • valueUUID - string - ValueUUID is the UUID of the label value. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AssignLabelByUUID" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	assignLabelByUUIDResp, err := incidentsService.AssignLabelByUUID(ctx, main.AssignLabelByUUIDRequest{
		IncidentID: "incident-123",
		KeyUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		ValueUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9160f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Labels: %+v\n", assignLabelByUUIDResp.Labels)
	log.Printf("Error: %+v\n", assignLabelByUUIDResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AssignLabelByUUID
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// AssignLabelByUUID assigns a keyUUID:valueUUID label to the incident
const incidentsServiceResp = await incidentsService.assignLabelByUUID({
	"incidentID": "incident-123",
	"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"labels", incidentsServiceResp.data.labels});

AssignLabelByUUIDResponse

A 200 response with an empty error field indicates that the request was successful.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		}
	]
}

AssignRole

AssignRole assigns a role to a user.

AssignRoleRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
  • userID - string - UserID is the identifier of the person to assign the role to. Is Required.
  • role - string - options: "commander" "investigator" "observer" - Role is the role of this person. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AssignRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"role": "commander",
	"userID": "grafana-incident:user-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	assignRoleResp, err := incidentsService.AssignRole(ctx, main.AssignRoleRequest{
		IncidentID: "incident-123",
		UserID: "grafana-incident:user-123",
		Role: "commander",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", assignRoleResp.Incident)
	log.Printf("DidChange: %+v\n", assignRoleResp.DidChange)
	log.Printf("Error: %+v\n", assignRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.AssignRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"role": "commander",
	"userID": "grafana-incident:user-123"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// AssignRole assigns a role to a user.
const incidentsServiceResp = await incidentsService.assignRole({
	"incidentID": "incident-123",
	"role": "commander",
	"userID": "grafana-incident:user-123"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});
console.info({"didChange", incidentsServiceResp.data.didChange});

AssignRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just updated.
  • didChange - boolean - DidChange indicates if the role was changed or not. If the role was already assigned, this will be false.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"didChange": true,
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

CreateIncident

CreateIncident creates a new Incident.

CreateIncidentRequest

  • title - string - Title is the headline title of the Incident. Shorter the better, but should contain enough information to be able to identify and refer to this issue. Is Required.
  • severity - string - Severity expresses how bad the Incident is. Is Required.
  • labels - array of IncidentLabel - Labels are the labels associated with the Incident. Only the Label string is processed, the other fields are ignored.
  • roomPrefix - string - RoomPrefix is the prefix that will be used to create the Incident room. Is Required.
  • isDrill - boolean - IsDrill indicates if the Incident is a drill or not. Incidents that are drills do not show up in the dashboards, and may behave subtly differently in other ways too. For example, during drills, more help might be offered to users. Is Required.
  • status - string - options: "active" "resolved" - Status is the starting status of the Incident. Use “resolved” to open a retrospective incident. Is Required.
  • attachCaption - string - AttachCaption is the title of associated URL.
  • attachURL - string - AttachURLis the associated URL. Maximum length: 2048.
  • alertGroupID - string - AlertGroupID is the identifier of the alert group associated with this incident.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.CreateIncident" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"alertGroupID": "I2K2GMRNHZ9NS",
	"attachCaption": "Grafana Incident: Powerful incident management, built on top of Grafana",
	"attachURL": "https://grafana.com/products/incident",
	"isDrill": true,
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"label": "customers-affected"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"label": "customers-affected"
		}
	],
	"roomPrefix": "incident",
	"severity": "minor",
	"status": "active",
	"title": "High latency in web requests"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	createIncidentResp, err := incidentsService.CreateIncident(ctx, main.CreateIncidentRequest{
		Title: "High latency in web requests",
		Severity: "minor",
		Labels: main.IncidentLabel{
			Key: "service_name",
			Label: "customers-affected",
			Description: "Customers are affected by this incident.",
			ColorHex: "#ff0000",
		},
		RoomPrefix: "incident",
		IsDrill: true,
		Status: "active",
		AttachCaption: "Grafana Incident: Powerful incident management, built on top of Grafana",
		AttachURL: "https://grafana.com/products/incident",
		AlertGroupID: "I2K2GMRNHZ9NS",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", createIncidentResp.Incident)
	log.Printf("Error: %+v\n", createIncidentResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.CreateIncident
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"alertGroupID": "I2K2GMRNHZ9NS",
	"attachCaption": "Grafana Incident: Powerful incident management, built on top of Grafana",
	"attachURL": "https://grafana.com/products/incident",
	"isDrill": true,
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"label": "customers-affected"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"label": "customers-affected"
		}
	],
	"roomPrefix": "incident",
	"severity": "minor",
	"status": "active",
	"title": "High latency in web requests"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// CreateIncident creates a new Incident.
const incidentsServiceResp = await incidentsService.createIncident({
	"alertGroupID": "I2K2GMRNHZ9NS",
	"attachCaption": "Grafana Incident: Powerful incident management, built on top of Grafana",
	"attachURL": "https://grafana.com/products/incident",
	"isDrill": true,
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"label": "customers-affected"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"label": "customers-affected"
		}
	],
	"roomPrefix": "incident",
	"severity": "minor",
	"status": "active",
	"title": "High latency in web requests"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

CreateIncidentResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was created.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

GetIncident

GetIncident gets an existing Incident by ID.

GetIncidentRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.GetIncident" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	getIncidentResp, err := incidentsService.GetIncident(ctx, main.GetIncidentRequest{
		IncidentID: "incident-123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", getIncidentResp.Incident)
	log.Printf("Error: %+v\n", getIncidentResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.GetIncident
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// GetIncident gets an existing Incident by ID.
const incidentsServiceResp = await incidentsService.getIncident({
	"incidentID": "incident-123"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

GetIncidentResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

GetIncidentMembership

GetIncidentMembership will return the full list of people involved in an incident

GetIncidentMembershipRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.GetIncidentMembership" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "1"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	getIncidentMembershipResp, err := incidentsService.GetIncidentMembership(ctx, main.GetIncidentMembershipRequest{
		IncidentID: "1",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Assignments: %+v\n", getIncidentMembershipResp.Assignments)
	log.Printf("Error: %+v\n", getIncidentMembershipResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.GetIncidentMembership
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "1"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// GetIncidentMembership will return the full list of people involved in an incident
const incidentsServiceResp = await incidentsService.getIncidentMembership({
	"incidentID": "1"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"assignments", incidentsServiceResp.data.assignments});

GetIncidentMembershipResponse

A 200 response with an empty error field indicates that the request was successful.

  • assignments - array of Assignment - IncidentMembership is the list of people involved in an incident
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"assignments": [
		{
			"role": {
				"archived": true,
				"createdAt": "2020-01-01T00:00:00Z",
				"description": "The commander is the incident commander.",
				"important": true,
				"mandatory": true,
				"name": "commander",
				"orgID": "org-1",
				"roleID": 1,
				"updatedAt": "2020-01-01T00:00:00Z"
			},
			"roleID": 1,
			"user": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			}
		},
		{
			"role": {
				"archived": true,
				"createdAt": "2020-01-01T00:00:00Z",
				"description": "The commander is the incident commander.",
				"important": true,
				"mandatory": true,
				"name": "commander",
				"orgID": "org-1",
				"roleID": 1,
				"updatedAt": "2020-01-01T00:00:00Z"
			},
			"roleID": 1,
			"user": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			}
		}
	],
	"error": "something went wrong"
}

GetLabels

GetLabels get the labels from the incident.

GetLabelsRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.GetLabels" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	getLabelsResp, err := incidentsService.GetLabels(ctx, main.GetLabelsRequest{
		IncidentID: "incident-123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Labels: %+v\n", getLabelsResp.Labels)
	log.Printf("Error: %+v\n", getLabelsResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.GetLabels
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// GetLabels get the labels from the incident.
const incidentsServiceResp = await incidentsService.getLabels({
	"incidentID": "incident-123"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"labels", incidentsServiceResp.data.labels});

GetLabelsResponse

A 200 response with an empty error field indicates that the request was successful.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		}
	]
}

QueryIncidentPreviews

QueryIncidentPreviews gets a list of Incident Previews.

QueryIncidentPreviewsRequest

  • query - IncidentPreviewsQuery - Query describes the query to make.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
  • includeCustomFieldValues - boolean - IncludeCustomFieldValues if true will include custom field values in the response.
  • includeMembershipPreview - boolean - IncludeMembershipPreview if true will include membership previews in the response.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.QueryIncidentPreviews" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"includeCustomFieldValues": true,
	"includeMembershipPreview": true,
	"query": {
		"limit": 10,
		"orderDirection": "ASC",
		"orderField": "createdTime",
		"queryString": "isdrill:false or(label:security label:important)"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	queryIncidentPreviewsResp, err := incidentsService.QueryIncidentPreviews(ctx, main.QueryIncidentPreviewsRequest{
		Query: main.IncidentPreviewsQuery{
			Limit: 10,
			OrderDirection: "ASC",
			OrderField: "createdTime",
			QueryString: "isdrill:false or(label:security label:important)",
		},
		Cursor: main.Cursor{
			NextValue: "123e4567-e89b-12d3-a456-426614174000",
			HasMore: true,
		},
		IncludeCustomFieldValues: true,
		IncludeMembershipPreview: true,
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("IncidentPreviews: %+v\n", queryIncidentPreviewsResp.IncidentPreviews)
	log.Printf("Query: %+v\n", queryIncidentPreviewsResp.Query)
	log.Printf("Cursor: %+v\n", queryIncidentPreviewsResp.Cursor)
	log.Printf("Error: %+v\n", queryIncidentPreviewsResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.QueryIncidentPreviews
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"includeCustomFieldValues": true,
	"includeMembershipPreview": true,
	"query": {
		"limit": 10,
		"orderDirection": "ASC",
		"orderField": "createdTime",
		"queryString": "isdrill:false or(label:security label:important)"
	}
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// QueryIncidentPreviews gets a list of Incident Previews.
const incidentsServiceResp = await incidentsService.queryIncidentPreviews({
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"includeCustomFieldValues": true,
	"includeMembershipPreview": true,
	"query": {
		"limit": 10,
		"orderDirection": "ASC",
		"orderField": "createdTime",
		"queryString": "isdrill:false or(label:security label:important)"
	}
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incidentPreviews", incidentsServiceResp.data.incidentPreviews});
console.info({"query", incidentsServiceResp.data.query});
console.info({"cursor", incidentsServiceResp.data.cursor});

QueryIncidentPreviewsResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidentPreviews - array of IncidentPreview - IncidentPreviews is a list of Incident Previews.
  • query - IncidentPreviewsQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"error": "something went wrong",
	"incidentPreviews": [
		{
			"closedTime": "2021-08-07T11:58:23Z",
			"createdByUser": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"createdTime": "2021-08-07T11:58:23Z",
			"description": "Looks like there is a problem with the load balancers...",
			"fieldValues": [
				{
					"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				},
				{
					"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				}
			],
			"heroImagePath": "/incident/api/hero-images/1234/mb6SVYPti2uY1qOokhs2mavgMFOtqDe/v1234/1234.png",
			"incidentEnd": "2022-02-11 00:50:20.574137",
			"incidentID": "incident-123",
			"incidentMembershipPreview": {
				"importantAssignments": [
					{
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					},
					{
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					}
				],
				"totalAssignments": 5,
				"totalParticipants": 3
			},
			"incidentStart": "2022-02-11 00:50:20.574137",
			"incidentType": "internal",
			"isDrill": true,
			"labels": [
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				},
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				}
			],
			"modifiedTime": "2021-08-07T11:58:23Z",
			"severityID": "severity-123",
			"severityLabel": "major",
			"slug": "high-latency-in-web-requests",
			"status": "active",
			"summary": "Lighting struck the server so we lost some throughput. We sprayed it with an 8-bit fire extinguisher and now it's back to normal.",
			"title": "high latency in web requests",
			"version": 4
		},
		{
			"closedTime": "2021-08-07T11:58:23Z",
			"createdByUser": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"createdTime": "2021-08-07T11:58:23Z",
			"description": "Looks like there is a problem with the load balancers...",
			"fieldValues": [
				{
					"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				},
				{
					"fieldUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
					"value": "value"
				}
			],
			"heroImagePath": "/incident/api/hero-images/1234/mb6SVYPti2uY1qOokhs2mavgMFOtqDe/v1234/1234.png",
			"incidentEnd": "2022-02-11 00:50:20.574137",
			"incidentID": "incident-123",
			"incidentMembershipPreview": {
				"importantAssignments": [
					{
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					},
					{
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					}
				],
				"totalAssignments": 5,
				"totalParticipants": 3
			},
			"incidentStart": "2022-02-11 00:50:20.574137",
			"incidentType": "internal",
			"isDrill": true,
			"labels": [
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				},
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				}
			],
			"modifiedTime": "2021-08-07T11:58:23Z",
			"severityID": "severity-123",
			"severityLabel": "major",
			"slug": "high-latency-in-web-requests",
			"status": "active",
			"summary": "Lighting struck the server so we lost some throughput. We sprayed it with an 8-bit fire extinguisher and now it's back to normal.",
			"title": "high latency in web requests",
			"version": 4
		}
	],
	"query": {
		"limit": 10,
		"orderDirection": "ASC",
		"orderField": "createdTime",
		"queryString": "isdrill:false or(label:security label:important)"
	}
}

QueryIncidents

QueryIncidents gets a list of Incidents.
Deprecated: use QueryIncidentPreviews instead.

QueryIncidentsRequest

  • query - IncidentsQuery - Query describes the query to make.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.QueryIncidents" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"dateFrom": "2021-01-01T02:07:14+00:00",
		"dateTo": "2021-01-01T02:07:14+00:00",
		"excludeStatuses": [
			"active",
			"resolved"
		],
		"incidentLabels": [
			"security",
			"customersaffected"
		],
		"includeStatuses": [
			"active",
			"resolved"
		],
		"limit": 10,
		"onlyDrills": true,
		"orderDirection": "ASC",
		"queryString": "isdrill:false any(label:security label:important)",
		"severity": "major"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	queryIncidentsResp, err := incidentsService.QueryIncidents(ctx, main.QueryIncidentsRequest{
		Query: main.IncidentsQuery{
			Limit: 10,
			IncludeStatuses: ["active","resolved"],
			ExcludeStatuses: ["active","resolved"],
			IncidentLabels: ["security","customersaffected"],
			DateFrom: "2021-01-01T02:07:14+00:00",
			DateTo: "2021-01-01T02:07:14+00:00",
			OnlyDrills: true,
			OrderDirection: "ASC",
			Severity: "major",
			QueryString: "isdrill:false any(label:security label:important)",
		},
		Cursor: main.Cursor{
			NextValue: "123e4567-e89b-12d3-a456-426614174000",
			HasMore: true,
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incidents: %+v\n", queryIncidentsResp.Incidents)
	log.Printf("Query: %+v\n", queryIncidentsResp.Query)
	log.Printf("Cursor: %+v\n", queryIncidentsResp.Cursor)
	log.Printf("Error: %+v\n", queryIncidentsResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.QueryIncidents
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"dateFrom": "2021-01-01T02:07:14+00:00",
		"dateTo": "2021-01-01T02:07:14+00:00",
		"excludeStatuses": [
			"active",
			"resolved"
		],
		"incidentLabels": [
			"security",
			"customersaffected"
		],
		"includeStatuses": [
			"active",
			"resolved"
		],
		"limit": 10,
		"onlyDrills": true,
		"orderDirection": "ASC",
		"queryString": "isdrill:false any(label:security label:important)",
		"severity": "major"
	}
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// QueryIncidents gets a list of Incidents.
const incidentsServiceResp = await incidentsService.queryIncidents({
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"dateFrom": "2021-01-01T02:07:14+00:00",
		"dateTo": "2021-01-01T02:07:14+00:00",
		"excludeStatuses": [
			"active",
			"resolved"
		],
		"incidentLabels": [
			"security",
			"customersaffected"
		],
		"includeStatuses": [
			"active",
			"resolved"
		],
		"limit": 10,
		"onlyDrills": true,
		"orderDirection": "ASC",
		"queryString": "isdrill:false any(label:security label:important)",
		"severity": "major"
	}
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incidents", incidentsServiceResp.data.incidents});
console.info({"query", incidentsServiceResp.data.query});
console.info({"cursor", incidentsServiceResp.data.cursor});

QueryIncidentsResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidents - array of Incident - Incidents is a list of Incidents.
  • query - IncidentsQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"error": "something went wrong",
	"incidents": [
		{
			"closedTime": "2021-08-07T11:58:23Z",
			"createdByUser": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"createdTime": "2021-08-07T11:58:23Z",
			"durationSeconds": 60,
			"heroImagePath": "/relative/path/to/hero/image.png",
			"incidentEnd": "2022-02-11 00:50:20.574137",
			"incidentID": "incident-123",
			"incidentMembership": {
				"assignments": [
					{
						"role": {
							"archived": true,
							"createdAt": "2020-01-01T00:00:00Z",
							"description": "The commander is the incident commander.",
							"important": true,
							"mandatory": true,
							"name": "commander",
							"orgID": "org-1",
							"roleID": 1,
							"updatedAt": "2020-01-01T00:00:00Z"
						},
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					},
					{
						"role": {
							"archived": true,
							"createdAt": "2020-01-01T00:00:00Z",
							"description": "The commander is the incident commander.",
							"important": true,
							"mandatory": true,
							"name": "commander",
							"orgID": "org-1",
							"roleID": 1,
							"updatedAt": "2020-01-01T00:00:00Z"
						},
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					}
				],
				"totalAssignments": 5,
				"totalParticipants": 3
			},
			"incidentStart": "2022-02-11 00:50:20.574137",
			"isDrill": true,
			"labels": [
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				},
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				}
			],
			"modifiedTime": "2021-08-07T11:58:23Z",
			"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
			"refs": [
				{
					"key": "com.grafana.oncall",
					"ref": "abc123",
					"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
				},
				{
					"key": "com.grafana.oncall",
					"ref": "abc123",
					"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
				}
			],
			"severity": "minor",
			"status": "active",
			"summary": "Something happened, we found out something interesting, then we fixed it.",
			"taskList": {
				"doneCount": 8,
				"tasks": [
					{
						"assignedUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"authorUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"createdTime": "2018-01-01T00:00:00Z",
						"immutable": true,
						"modifiedTime": "2018-01-01T00:00:00Z",
						"status": "todo",
						"taskID": "task-123456",
						"text": "Assign an investigator"
					},
					{
						"assignedUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"authorUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"createdTime": "2018-01-01T00:00:00Z",
						"immutable": true,
						"modifiedTime": "2018-01-01T00:00:00Z",
						"status": "todo",
						"taskID": "task-123456",
						"text": "Assign an investigator"
					}
				],
				"todoCount": 5
			},
			"title": "high latency in web requests"
		},
		{
			"closedTime": "2021-08-07T11:58:23Z",
			"createdByUser": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"createdTime": "2021-08-07T11:58:23Z",
			"durationSeconds": 60,
			"heroImagePath": "/relative/path/to/hero/image.png",
			"incidentEnd": "2022-02-11 00:50:20.574137",
			"incidentID": "incident-123",
			"incidentMembership": {
				"assignments": [
					{
						"role": {
							"archived": true,
							"createdAt": "2020-01-01T00:00:00Z",
							"description": "The commander is the incident commander.",
							"important": true,
							"mandatory": true,
							"name": "commander",
							"orgID": "org-1",
							"roleID": 1,
							"updatedAt": "2020-01-01T00:00:00Z"
						},
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					},
					{
						"role": {
							"archived": true,
							"createdAt": "2020-01-01T00:00:00Z",
							"description": "The commander is the incident commander.",
							"important": true,
							"mandatory": true,
							"name": "commander",
							"orgID": "org-1",
							"roleID": 1,
							"updatedAt": "2020-01-01T00:00:00Z"
						},
						"roleID": 1,
						"user": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						}
					}
				],
				"totalAssignments": 5,
				"totalParticipants": 3
			},
			"incidentStart": "2022-02-11 00:50:20.574137",
			"isDrill": true,
			"labels": [
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				},
				{
					"colorHex": "#ff0000",
					"description": "Customers are affected by this incident.",
					"key": "service_name",
					"label": "customers-affected"
				}
			],
			"modifiedTime": "2021-08-07T11:58:23Z",
			"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
			"refs": [
				{
					"key": "com.grafana.oncall",
					"ref": "abc123",
					"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
				},
				{
					"key": "com.grafana.oncall",
					"ref": "abc123",
					"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
				}
			],
			"severity": "minor",
			"status": "active",
			"summary": "Something happened, we found out something interesting, then we fixed it.",
			"taskList": {
				"doneCount": 8,
				"tasks": [
					{
						"assignedUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"authorUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"createdTime": "2018-01-01T00:00:00Z",
						"immutable": true,
						"modifiedTime": "2018-01-01T00:00:00Z",
						"status": "todo",
						"taskID": "task-123456",
						"text": "Assign an investigator"
					},
					{
						"assignedUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"authorUser": {
							"name": "Morty Smith",
							"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
							"userID": "user-123"
						},
						"createdTime": "2018-01-01T00:00:00Z",
						"immutable": true,
						"modifiedTime": "2018-01-01T00:00:00Z",
						"status": "todo",
						"taskID": "task-123456",
						"text": "Assign an investigator"
					}
				],
				"todoCount": 5
			},
			"title": "high latency in web requests"
		}
	],
	"query": {
		"dateFrom": "2021-01-01T02:07:14+00:00",
		"dateTo": "2021-01-01T02:07:14+00:00",
		"excludeStatuses": [
			"active",
			"resolved"
		],
		"incidentLabels": [
			"security",
			"customersaffected"
		],
		"includeStatuses": [
			"active",
			"resolved"
		],
		"limit": 10,
		"onlyDrills": true,
		"orderDirection": "ASC",
		"queryString": "isdrill:false any(label:security label:important)",
		"severity": "major"
	}
}

RemoveLabel

RemoveLabel removes a label from the Incident.

RemoveLabelRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • label - string - Label is the label to remove from the Incident.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.RemoveLabel" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"label": "customers-affected"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	removeLabelResp, err := incidentsService.RemoveLabel(ctx, main.RemoveLabelRequest{
		IncidentID: "incident-123",
		Label: "customers-affected",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", removeLabelResp.Incident)
	log.Printf("Error: %+v\n", removeLabelResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.RemoveLabel
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"label": "customers-affected"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// RemoveLabel removes a label from the Incident.
const incidentsServiceResp = await incidentsService.removeLabel({
	"incidentID": "incident-123",
	"label": "customers-affected"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

RemoveLabelResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

UnassignLabel

UnassignLabel unassigns a key:value label from the incident

UnassignLabelRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • key - string - Key is the label key. Is Required.
  • value - string - Value is the value of the label. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UnassignLabel" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"key": "service_name",
	"value": "customers-affected"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	unassignLabelResp, err := incidentsService.UnassignLabel(ctx, main.UnassignLabelRequest{
		IncidentID: "incident-123",
		Key: "service_name",
		Value: "customers-affected",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Labels: %+v\n", unassignLabelResp.Labels)
	log.Printf("Error: %+v\n", unassignLabelResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UnassignLabel
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"key": "service_name",
	"value": "customers-affected"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UnassignLabel unassigns a key:value label from the incident
const incidentsServiceResp = await incidentsService.unassignLabel({
	"incidentID": "incident-123",
	"key": "service_name",
	"value": "customers-affected"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"labels", incidentsServiceResp.data.labels});

UnassignLabelResponse

A 200 response with an empty error field indicates that the request was successful.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		}
	]
}

UnassignLabelByUUID

UnassignLabelByUUID unassigns a keyUUID:valueUUID label from the incident

UnassignLabelByUUIDRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • keyUUID - string - KeyUUID is the label key uuid. Is Required.
  • valueUUID - string - ValueUUID is the UUID of the label value. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UnassignLabelByUUID" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	unassignLabelByUUIDResp, err := incidentsService.UnassignLabelByUUID(ctx, main.UnassignLabelByUUIDRequest{
		IncidentID: "incident-123",
		KeyUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
		ValueUUID: "3fb1e5d7-3ef2-11ef-b731-deab26f9160f",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Labels: %+v\n", unassignLabelByUUIDResp.Labels)
	log.Printf("Error: %+v\n", unassignLabelByUUIDResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UnassignLabelByUUID
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UnassignLabelByUUID unassigns a keyUUID:valueUUID label from the incident
const incidentsServiceResp = await incidentsService.unassignLabelByUUID({
	"incidentID": "incident-123",
	"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
	"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"labels", incidentsServiceResp.data.labels});

UnassignLabelByUUIDResponse

A 200 response with an empty error field indicates that the request was successful.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"labels": [
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		},
		{
			"colorHex": "#ff0000",
			"description": "Customers are affected by this incident.",
			"key": "service_name",
			"keyUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9180f",
			"value": "customers-affected",
			"valueUUID": "3fb1e5d7-3ef2-11ef-b731-deab26f9160f"
		}
	]
}

UnassignRole

UnassignRole removes a role assignment from a user.

UnassignRoleRequest

  • incidentID - string - IncidentID is the identifier. Is Required.
  • userID - string - UserID is the identifier of the person to assign the role to. Is Required.
  • role - string - options: "commander" "investigator" "observer" - Role is the role of this person. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UnassignRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"role": "commander",
	"userID": "grafana-incident:user-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	unassignRoleResp, err := incidentsService.UnassignRole(ctx, main.UnassignRoleRequest{
		IncidentID: "incident-123",
		UserID: "grafana-incident:user-123",
		Role: "commander",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", unassignRoleResp.Incident)
	log.Printf("DidChange: %+v\n", unassignRoleResp.DidChange)
	log.Printf("Error: %+v\n", unassignRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UnassignRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"role": "commander",
	"userID": "grafana-incident:user-123"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UnassignRole removes a role assignment from a user.
const incidentsServiceResp = await incidentsService.unassignRole({
	"incidentID": "incident-123",
	"role": "commander",
	"userID": "grafana-incident:user-123"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});
console.info({"didChange", incidentsServiceResp.data.didChange});

UnassignRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just updated.
  • didChange - boolean - DidChange indicates if the role was changed or not. If the role was not assigned, this will be false.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"didChange": true,
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

UpdateIncidentEventTime

UpdateIncidentEventTime updates the start or end times of an Incident.

UpdateIncidentEventTimeRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • eventTime - string - EventTime is the new time for the start or end of the incident. The string value format should follow RFC 3339. Is Required.
  • activityItemKind - string - options: "incidentEnd" "incidentStart" - ActivityItemKind is either the incidentEnd or incidentStart time. deprecated. use EventName instead, ActivityItemKind will be removed soon. Is Required. (Deprecated: true)
  • eventName - string - options: "incidentEnd" "incidentStart" - EventName is either the incidentEnd or incidentStart time. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateIncidentEventTime" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"activityItemKind": "incidentEnd",
	"eventName": "incidentEnd",
	"eventTime": "2022-02-11 00:50:20.574137",
	"incidentID": "1"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	updateIncidentEventTimeResp, err := incidentsService.UpdateIncidentEventTime(ctx, main.UpdateIncidentEventTimeRequest{
		IncidentID: "1",
		EventTime: "2022-02-11 00:50:20.574137",
		ActivityItemKind: "incidentEnd",
		EventName: "incidentEnd",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", updateIncidentEventTimeResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateIncidentEventTime
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"activityItemKind": "incidentEnd",
	"eventName": "incidentEnd",
	"eventTime": "2022-02-11 00:50:20.574137",
	"incidentID": "1"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const incidentsService = new IncidentsService(client);

// UpdateIncidentEventTime updates the start or end times of an Incident.
const incidentsServiceResp = await incidentsService.updateIncidentEventTime({
  activityItemKind: 'incidentEnd',
  eventName: 'incidentEnd',
  eventTime: '2022-02-11 00:50:20.574137',
  incidentID: '1',
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response

UpdateIncidentEventTimeResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

UpdateIncidentIsDrill

UpdateIncidentIsDrill changes whether an Incident is a drill or not.

UpdateIncidentIsDrillRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • isDrill - boolean - IsDrill indicates whether the Incident is a drill or not.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateIncidentIsDrill" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"isDrill": true
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	updateIncidentIsDrillResp, err := incidentsService.UpdateIncidentIsDrill(ctx, main.UpdateIncidentIsDrillRequest{
		IncidentID: "incident-123",
		IsDrill: true,
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", updateIncidentIsDrillResp.Incident)
	log.Printf("Error: %+v\n", updateIncidentIsDrillResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateIncidentIsDrill
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"isDrill": true
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UpdateIncidentIsDrill changes whether an Incident is a drill or not.
const incidentsServiceResp = await incidentsService.updateIncidentIsDrill({
	"incidentID": "incident-123",
	"isDrill": true
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

UpdateIncidentIsDrillResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

UpdateSeverity

UpdateSeverity updates the severity of an Incident.

UpdateSeverityRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • severity - string - Severity expresses how bad the Incident is. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateSeverity" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"severity": "minor"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	updateSeverityResp, err := incidentsService.UpdateSeverity(ctx, main.UpdateSeverityRequest{
		IncidentID: "incident-123",
		Severity: "minor",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", updateSeverityResp.Incident)
	log.Printf("Error: %+v\n", updateSeverityResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateSeverity
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"severity": "minor"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UpdateSeverity updates the severity of an Incident.
const incidentsServiceResp = await incidentsService.updateSeverity({
	"incidentID": "incident-123",
	"severity": "minor"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

UpdateSeverityResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

UpdateStatus

UpdateStatus updates the status of an Incident.

UpdateStatusRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • status - string - options: "active" "resolved" - Status is the new status of the Incident. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateStatus" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"status": "resolved"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	updateStatusResp, err := incidentsService.UpdateStatus(ctx, main.UpdateStatusRequest{
		IncidentID: "incident-123",
		Status: "resolved",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", updateStatusResp.Incident)
	log.Printf("Error: %+v\n", updateStatusResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateStatus
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"status": "resolved"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UpdateStatus updates the status of an Incident.
const incidentsServiceResp = await incidentsService.updateStatus({
	"incidentID": "incident-123",
	"status": "resolved"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

UpdateStatusResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

UpdateTitle

UpdateTitle updates the title of an Incident.

UpdateTitleRequest

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • title - string - Title is the new title of the Incident. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateTitle" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123",
	"title": "High latency in web requests"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	incidentsService := incident.NewIncidentsService(client)
	// make the request...
	updateTitleResp, err := incidentsService.UpdateTitle(ctx, main.UpdateTitleRequest{
		IncidentID: "incident-123",
		Title: "High latency in web requests",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Incident: %+v\n", updateTitleResp.Incident)
	log.Printf("Error: %+v\n", updateTitleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IncidentsService.UpdateTitle
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123",
	"title": "High latency in web requests"
}
JavaScript
import { GrafanaIncidentClient, IncidentsService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const incidentsService = new IncidentsService(client);

// UpdateTitle updates the title of an Incident.
const incidentsServiceResp = await incidentsService.updateTitle({
	"incidentID": "incident-123",
	"title": "High latency in web requests"
});

if (!incidentsServiceResp.success) {
  // handle the error
  throw new Error(incidentsServiceResp.error);
}

// access the fields of the response
console.info({"incident", incidentsServiceResp.data.incident});

UpdateTitleResponse

A 200 response with an empty error field indicates that the request was successful.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incident": {
		"closedTime": "2021-08-07T11:58:23Z",
		"createdByUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"durationSeconds": 60,
		"heroImagePath": "/relative/path/to/hero/image.png",
		"incidentEnd": "2022-02-11 00:50:20.574137",
		"incidentID": "incident-123",
		"incidentMembership": {
			"assignments": [
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				},
				{
					"role": {
						"archived": true,
						"createdAt": "2020-01-01T00:00:00Z",
						"description": "The commander is the incident commander.",
						"important": true,
						"mandatory": true,
						"name": "commander",
						"orgID": "org-1",
						"roleID": 1,
						"updatedAt": "2020-01-01T00:00:00Z"
					},
					"roleID": 1,
					"user": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					}
				}
			],
			"totalAssignments": 5,
			"totalParticipants": 3
		},
		"incidentStart": "2022-02-11 00:50:20.574137",
		"isDrill": true,
		"labels": [
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			},
			{
				"colorHex": "#ff0000",
				"description": "Customers are affected by this incident.",
				"key": "service_name",
				"label": "customers-affected"
			}
		],
		"modifiedTime": "2021-08-07T11:58:23Z",
		"overviewURL": "/a/grafana-irm-app/incidents/incident-123/title",
		"refs": [
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			},
			{
				"key": "com.grafana.oncall",
				"ref": "abc123",
				"url": "https://grafana.com/a/grafana-irm-app/incidents/456"
			}
		],
		"severity": "minor",
		"status": "active",
		"summary": "Something happened, we found out something interesting, then we fixed it.",
		"taskList": {
			"doneCount": 8,
			"tasks": [
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				},
				{
					"assignedUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"authorUser": {
						"name": "Morty Smith",
						"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
						"userID": "user-123"
					},
					"createdTime": "2018-01-01T00:00:00Z",
					"immutable": true,
					"modifiedTime": "2018-01-01T00:00:00Z",
					"status": "todo",
					"taskID": "task-123456",
					"text": "Assign an investigator"
				}
			],
			"todoCount": 5
		},
		"title": "high latency in web requests"
	}
}

IntegrationService

IntegrationService is used to install Integrations, and wire up hooks.

DisableHook

DisableHook disables a Hook.

DisableHookRequest

  • integrationID - string - IntegrationID is the identifier of the installed integration. Is Required.
  • enabledHookID - string - EnabledHookID is the identifier of the hook to disable. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.DisableHook" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"enabledHookID": "enabled-hook-123",
	"integrationID": "integration-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	integrationService := incident.NewIntegrationService(client)
	// make the request...
	disableHookResp, err := integrationService.DisableHook(ctx, main.DisableHookRequest{
		IntegrationID: "integration-123",
		EnabledHookID: "enabled-hook-123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", disableHookResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.DisableHook
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"enabledHookID": "enabled-hook-123",
	"integrationID": "integration-123"
}
JavaScript
import { GrafanaIncidentClient, IntegrationService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const integrationService = new IntegrationService(client);

// DisableHook disables a Hook.
const integrationServiceResp = await integrationService.disableHook({
  enabledHookID: 'enabled-hook-123',
  integrationID: 'integration-123',
});

if (!integrationServiceResp.success) {
  // handle the error
  throw new Error(integrationServiceResp.error);
}

// access the fields of the response

DisableHookResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

EnableHook

EnableHook wires up a Hook to an event.

EnableHookRequest

  • integrationID - string - IntegrationID is the identifier of the installed integration. Is Required.
  • hookID - string - HookID is the identifier of the hook to enable. Is Required.
  • eventName - string - options: "incidentCreated" "incidentDeleted" "incidentUpdated" "incidentClosed" "manuallyTriggered" "incidentFilter" - EventName is the name of event to wire the hook up to. The hook will be called when this event is fired. Is Required.
  • hookConfig - HookConfig - HookConfig is the configuration values to use when enabling the hook.
  • incidentFilter - string - IncidentFilter is the filter that determines if a hook with the ‘incidentFilter’ event will be triggered.
  • sensitive - boolean - Sensitive is true if the hook run should be triggered when the incident is private. Ensures that hooks are not triggered for private incidents by default.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.EnableHook" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"eventName": "incidentCreated",
	"hookConfig": {
		"fields": [
			{
				"checked": true,
				"description": "This field holds a very interesting setting.",
				"hidden": true,
				"key": "someInterestingSetting",
				"secret": true,
				"type": "string",
				"value": "setting-9"
			},
			{
				"checked": true,
				"description": "This field holds a very interesting setting.",
				"hidden": true,
				"key": "someInterestingSetting",
				"secret": true,
				"type": "string",
				"value": "setting-9"
			}
		]
	},
	"hookID": "hook-123",
	"incidentFilter": "isdrill:true",
	"integrationID": "integration-123",
	"sensitive": true
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	integrationService := incident.NewIntegrationService(client)
	// make the request...
	enableHookResp, err := integrationService.EnableHook(ctx, main.EnableHookRequest{
		IntegrationID: "integration-123",
		HookID: "hook-123",
		EventName: "incidentCreated",
		HookConfig: main.HookConfig{
			Fields: main.Field{
				Key: "someInterestingSetting",
				Type: "string",
				Description: "This field holds a very interesting setting.",
				Value: "setting-9",
				Secret: true,
				Checked: true,
				Hidden: true,
			},
		},
		IncidentFilter: "isdrill:true",
		Sensitive: true,
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("EnabledHookID: %+v\n", enableHookResp.EnabledHookID)
	log.Printf("Error: %+v\n", enableHookResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.EnableHook
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"eventName": "incidentCreated",
	"hookConfig": {
		"fields": [
			{
				"checked": true,
				"description": "This field holds a very interesting setting.",
				"hidden": true,
				"key": "someInterestingSetting",
				"secret": true,
				"type": "string",
				"value": "setting-9"
			},
			{
				"checked": true,
				"description": "This field holds a very interesting setting.",
				"hidden": true,
				"key": "someInterestingSetting",
				"secret": true,
				"type": "string",
				"value": "setting-9"
			}
		]
	},
	"hookID": "hook-123",
	"incidentFilter": "isdrill:true",
	"integrationID": "integration-123",
	"sensitive": true
}
JavaScript
import { GrafanaIncidentClient, IntegrationService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const integrationService = new IntegrationService(client);

// EnableHook wires up a Hook to an event.
const integrationServiceResp = await integrationService.enableHook({
	"eventName": "incidentCreated",
	"hookConfig": {
		"fields": [
			{
				"checked": true,
				"description": "This field holds a very interesting setting.",
				"hidden": true,
				"key": "someInterestingSetting",
				"secret": true,
				"type": "string",
				"value": "setting-9"
			},
			{
				"checked": true,
				"description": "This field holds a very interesting setting.",
				"hidden": true,
				"key": "someInterestingSetting",
				"secret": true,
				"type": "string",
				"value": "setting-9"
			}
		]
	},
	"hookID": "hook-123",
	"incidentFilter": "isdrill:true",
	"integrationID": "integration-123",
	"sensitive": true
});

if (!integrationServiceResp.success) {
  // handle the error
  throw new Error(integrationServiceResp.error);
}

// access the fields of the response
console.info({"enabledHookID", integrationServiceResp.data.enabledHookID});

EnableHookResponse

A 200 response with an empty error field indicates that the request was successful.

  • enabledHookID - string - EnabledHookID is the identifier of the enabled hook. This is distinct from the HookID. Is Required.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"enabledHookID": "enabled-hook-123",
	"error": "something went wrong"
}

GetEnabledHooks

GetEnabledHooks gets a list of all enabled Hooks.

GetEnabledHooksRequest

  • eventName - string - EventName is the name of the event that triggered the Hook to run. If provided, only Hooks that are enabled for this event will be returned.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.GetEnabledHooks" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"eventName": "incidentCreated"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	integrationService := incident.NewIntegrationService(client)
	// make the request...
	getEnabledHooksResp, err := integrationService.GetEnabledHooks(ctx, main.GetEnabledHooksRequest{
		EventName: "incidentCreated",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("EnabledHooks: %+v\n", getEnabledHooksResp.EnabledHooks)
	log.Printf("Error: %+v\n", getEnabledHooksResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.GetEnabledHooks
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"eventName": "incidentCreated"
}
JavaScript
import { GrafanaIncidentClient, IntegrationService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const integrationService = new IntegrationService(client);

// GetEnabledHooks gets a list of all enabled Hooks.
const integrationServiceResp = await integrationService.getEnabledHooks({
	"eventName": "incidentCreated"
});

if (!integrationServiceResp.success) {
  // handle the error
  throw new Error(integrationServiceResp.error);
}

// access the fields of the response
console.info({"enabledHooks", integrationServiceResp.data.enabledHooks});

GetEnabledHooksResponse

A 200 response with an empty error field indicates that the request was successful.

  • enabledHooks - array of EnabledHook - EnabledHooks is the complete list of enabled hooks.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"enabledHooks": [
		{
			"enabledHookID": "enabled-hook-123",
			"eventName": "incidentCreated",
			"hook": {
				"description": "A brief description of this Hook.",
				"hookID": "hook-123",
				"name": "Hook Name"
			},
			"incidentFilter": "isdrill:true",
			"integrationID": "integration-123",
			"sensitive": true
		},
		{
			"enabledHookID": "enabled-hook-123",
			"eventName": "incidentCreated",
			"hook": {
				"description": "A brief description of this Hook.",
				"hookID": "hook-123",
				"name": "Hook Name"
			},
			"incidentFilter": "isdrill:true",
			"integrationID": "integration-123",
			"sensitive": true
		}
	],
	"error": "something went wrong"
}

GetHookRuns

GetHookRuns gets a list of HookRuns for a given Incident.

GetHookRunsRequest

  • incidentID - string - IncidentID is the identifier of the incident to get hook runs for. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.GetHookRuns" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	integrationService := incident.NewIntegrationService(client)
	// make the request...
	getHookRunsResp, err := integrationService.GetHookRuns(ctx, main.GetHookRunsRequest{
		IncidentID: "incident-123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("HookRuns: %+v\n", getHookRunsResp.HookRuns)
	log.Printf("Error: %+v\n", getHookRunsResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/IntegrationService.GetHookRuns
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, IntegrationService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const integrationService = new IntegrationService(client);

// GetHookRuns gets a list of HookRuns for a given Incident.
const integrationServiceResp = await integrationService.getHookRuns({
	"incidentID": "incident-123"
});

if (!integrationServiceResp.success) {
  // handle the error
  throw new Error(integrationServiceResp.error);
}

// access the fields of the response
console.info({"hookRuns", integrationServiceResp.data.hookRuns});

GetHookRunsResponse

A 200 response with an empty error field indicates that the request was successful.

  • hookRuns - array of HookRun - HookRuns is a list of HookRuns for this Incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"hookRuns": [
		{
			"enabledHookID": "enabled-hook-123",
			"error": "Something went wrong",
			"eventKind": "updatedRole",
			"eventName": "incidentCreated",
			"hookID": "hook-123",
			"integrationID": "integration-123",
			"lastRun": "2020-01-01T00:00:00Z",
			"lastUpdate": "2020-01-01T00:00:00Z",
			"metadata": {
				"explanation": "A meeting was created.",
				"title": "Meeting Created",
				"url": "https://somewhere.com/123"
			},
			"status": "todo",
			"updateError": "failed to connect",
			"updateStatus": "todo"
		},
		{
			"enabledHookID": "enabled-hook-123",
			"error": "Something went wrong",
			"eventKind": "updatedRole",
			"eventName": "incidentCreated",
			"hookID": "hook-123",
			"integrationID": "integration-123",
			"lastRun": "2020-01-01T00:00:00Z",
			"lastUpdate": "2020-01-01T00:00:00Z",
			"metadata": {
				"explanation": "A meeting was created.",
				"title": "Meeting Created",
				"url": "https://somewhere.com/123"
			},
			"status": "todo",
			"updateError": "failed to connect",
			"updateStatus": "todo"
		}
	]
}

KeyUpdatesService

KeyUpdatesService provides functionality to manage key updates for incidents. Key updates represent significant milestones or critical updates during an incident's lifecycle.

CreateKeyUpdate

CreateKeyUpdate creates a new key update for an incident.

CreateKeyUpdateRequest

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • title - string - Title is a short summary of the key update.
  • content - string - Content provides detailed information about the key update. Is Required. Maximum length: 65536.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the format of the content. Is Required.
  • statusID - string - StatusID references the incident status at the time of this update.
  • severityID - string - SeverityID references the incident severity at the time of this update.
  • scope - string - options: "internal" "public" "private" - Scope specifies the audience or visibility of this key update. Is Required.
  • color - string - Color is the color of the key update.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.CreateKeyUpdate" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"color": "#000000",
	"content": "Database connection pool exhaustion identified as root cause",
	"contentType": "text/plain",
	"incidentID": "incident-123",
	"scope": "internal",
	"severityID": "severity-123",
	"statusID": "status-123",
	"title": "Root cause identified"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	createKeyUpdateResp, err := keyUpdatesService.CreateKeyUpdate(ctx, main.CreateKeyUpdateRequest{
		IncidentID: "incident-123",
		Title: "Root cause identified",
		Content: "Database connection pool exhaustion identified as root cause",
		ContentType: "text/plain",
		StatusID: "status-123",
		SeverityID: "severity-123",
		Scope: "internal",
		Color: "#000000",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("KeyUpdate: %+v\n", createKeyUpdateResp.KeyUpdate)
	log.Printf("Error: %+v\n", createKeyUpdateResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.CreateKeyUpdate
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"color": "#000000",
	"content": "Database connection pool exhaustion identified as root cause",
	"contentType": "text/plain",
	"incidentID": "incident-123",
	"scope": "internal",
	"severityID": "severity-123",
	"statusID": "status-123",
	"title": "Root cause identified"
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const keyUpdatesService = new KeyUpdatesService(client);

// CreateKeyUpdate creates a new key update for an incident.
const keyUpdatesServiceResp = await keyUpdatesService.createKeyUpdate({
	"color": "#000000",
	"content": "Database connection pool exhaustion identified as root cause",
	"contentType": "text/plain",
	"incidentID": "incident-123",
	"scope": "internal",
	"severityID": "severity-123",
	"statusID": "status-123",
	"title": "Root cause identified"
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response
console.info({"keyUpdate", keyUpdatesServiceResp.data.keyUpdate});

CreateKeyUpdateResponse

A 200 response with an empty error field indicates that the request was successful.

  • keyUpdate - KeyUpdate - KeyUpdate is the newly created key update.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"keyUpdate": {
		"color": "#000000",
		"content": "Database connection pool exhaustion identified as root cause",
		"contentType": "text/plain",
		"createdBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"id": "keyupdate-123",
		"incidentID": "incident-123",
		"lastModifiedBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"modifiedTime": "2021-08-07T11:58:23Z",
		"orgID": "org-123",
		"scope": "internal",
		"severityID": "severity-123",
		"statusID": "status-123",
		"title": "Root cause identified"
	}
}

DeleteKeyUpdate

DeleteKeyUpdate removes a key update.

DeleteKeyUpdateRequest

  • id - string - ID is the identifier of the key update to delete. Is Required.
  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.DeleteKeyUpdate" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"id": "keyupdate-123",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	deleteKeyUpdateResp, err := keyUpdatesService.DeleteKeyUpdate(ctx, main.DeleteKeyUpdateRequest{
		ID: "keyupdate-123",
		IncidentID: "incident-123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", deleteKeyUpdateResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.DeleteKeyUpdate
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"id": "keyupdate-123",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const keyUpdatesService = new KeyUpdatesService(client);

// DeleteKeyUpdate removes a key update.
const keyUpdatesServiceResp = await keyUpdatesService.deleteKeyUpdate({
  id: 'keyupdate-123',
  incidentID: 'incident-123',
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response

DeleteKeyUpdateResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

GetInitialKeyUpdate

GetInitialKeyUpdate gets the initial key update for an incident.

GetInitialKeyUpdateRequest

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.GetInitialKeyUpdate" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"contentType": "text/plain",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	getInitialKeyUpdateResp, err := keyUpdatesService.GetInitialKeyUpdate(ctx, main.GetInitialKeyUpdateRequest{
		IncidentID: "incident-123",
		ContentType: "text/plain",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("KeyUpdate: %+v\n", getInitialKeyUpdateResp.KeyUpdate)
	log.Printf("Error: %+v\n", getInitialKeyUpdateResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.GetInitialKeyUpdate
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"contentType": "text/plain",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const keyUpdatesService = new KeyUpdatesService(client);

// GetInitialKeyUpdate gets the initial key update for an incident.
const keyUpdatesServiceResp = await keyUpdatesService.getInitialKeyUpdate({
	"contentType": "text/plain",
	"incidentID": "incident-123"
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response
console.info({"keyUpdate", keyUpdatesServiceResp.data.keyUpdate});

GetInitialKeyUpdateResponse

A 200 response with an empty error field indicates that the request was successful.

  • keyUpdate - *KeyUpdate - KeyUpdate is the initial key update for the incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"keyUpdate": {
		"color": "#000000",
		"content": "Database connection pool exhaustion identified as root cause",
		"contentType": "text/plain",
		"createdBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"id": "keyupdate-123",
		"incidentID": "incident-123",
		"lastModifiedBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"modifiedTime": "2021-08-07T11:58:23Z",
		"orgID": "org-123",
		"scope": "internal",
		"severityID": "severity-123",
		"statusID": "status-123",
		"title": "Root cause identified"
	}
}

GetKeyUpdate

GetKeyUpdate retrieves a specific key update.

GetKeyUpdateRequest

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • id - string - ID is the identifier of the key update to retrieve. Is Required.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.GetKeyUpdate" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"contentType": "text/plain",
	"id": "keyupdate-123",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	getKeyUpdateResp, err := keyUpdatesService.GetKeyUpdate(ctx, main.GetKeyUpdateRequest{
		IncidentID: "incident-123",
		ID: "keyupdate-123",
		ContentType: "text/plain",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("KeyUpdate: %+v\n", getKeyUpdateResp.KeyUpdate)
	log.Printf("Error: %+v\n", getKeyUpdateResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.GetKeyUpdate
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"contentType": "text/plain",
	"id": "keyupdate-123",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const keyUpdatesService = new KeyUpdatesService(client);

// GetKeyUpdate retrieves a specific key update.
const keyUpdatesServiceResp = await keyUpdatesService.getKeyUpdate({
	"contentType": "text/plain",
	"id": "keyupdate-123",
	"incidentID": "incident-123"
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response
console.info({"keyUpdate", keyUpdatesServiceResp.data.keyUpdate});

GetKeyUpdateResponse

A 200 response with an empty error field indicates that the request was successful.

  • keyUpdate - KeyUpdate - KeyUpdate is the requested key update.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"keyUpdate": {
		"color": "#000000",
		"content": "Database connection pool exhaustion identified as root cause",
		"contentType": "text/plain",
		"createdBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"id": "keyupdate-123",
		"incidentID": "incident-123",
		"lastModifiedBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"modifiedTime": "2021-08-07T11:58:23Z",
		"orgID": "org-123",
		"scope": "internal",
		"severityID": "severity-123",
		"statusID": "status-123",
		"title": "Root cause identified"
	}
}

GetLastKeyUpdate

GetLastKeyUpdate gets the last key update for an incident.

GetLastKeyUpdateRequest

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.GetLastKeyUpdate" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"contentType": "text/plain",
	"incidentID": "incident-123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	getLastKeyUpdateResp, err := keyUpdatesService.GetLastKeyUpdate(ctx, main.GetLastKeyUpdateRequest{
		IncidentID: "incident-123",
		ContentType: "text/plain",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("KeyUpdate: %+v\n", getLastKeyUpdateResp.KeyUpdate)
	log.Printf("KeyUpdateCount: %+v\n", getLastKeyUpdateResp.KeyUpdateCount)
	log.Printf("Error: %+v\n", getLastKeyUpdateResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.GetLastKeyUpdate
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"contentType": "text/plain",
	"incidentID": "incident-123"
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const keyUpdatesService = new KeyUpdatesService(client);

// GetLastKeyUpdate gets the last key update for an incident.
const keyUpdatesServiceResp = await keyUpdatesService.getLastKeyUpdate({
	"contentType": "text/plain",
	"incidentID": "incident-123"
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response
console.info({"keyUpdate", keyUpdatesServiceResp.data.keyUpdate});
console.info({"keyUpdateCount", keyUpdatesServiceResp.data.keyUpdateCount});

GetLastKeyUpdateResponse

A 200 response with an empty error field indicates that the request was successful.

  • keyUpdate - *KeyUpdate - KeyUpdate is the last key update for the incident.
  • keyUpdateCount - number - Number of other key updates for this incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"keyUpdate": {
		"color": "#000000",
		"content": "Database connection pool exhaustion identified as root cause",
		"contentType": "text/plain",
		"createdBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"id": "keyupdate-123",
		"incidentID": "incident-123",
		"lastModifiedBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"modifiedTime": "2021-08-07T11:58:23Z",
		"orgID": "org-123",
		"scope": "internal",
		"severityID": "severity-123",
		"statusID": "status-123",
		"title": "Root cause identified"
	},
	"keyUpdateCount": 10
}

QueryKeyUpdates

QueryKeyUpdates gets a list of key updates with pagination support.

QueryKeyUpdatesRequest

  • query - KeyUpdatesQuery - Query describes the query parameters.
  • cursor - Cursor - Cursor is used for pagination. Empty for the first page. For subsequent pages, use previously returned Cursor values.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.QueryKeyUpdates" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"contentType": "text/plain",
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "DESC",
		"orderField": "createdTime",
		"scope": "internal"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	queryKeyUpdatesResp, err := keyUpdatesService.QueryKeyUpdates(ctx, main.QueryKeyUpdatesRequest{
		Query: main.KeyUpdatesQuery{
			IncidentID: "incident-123",
			Limit: 10,
			OrderDirection: "DESC",
			OrderField: "createdTime",
			Scope: "internal",
			ContentType: "text/plain",
		},
		Cursor: main.Cursor{
			NextValue: "123e4567-e89b-12d3-a456-426614174000",
			HasMore: true,
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("KeyUpdates: %+v\n", queryKeyUpdatesResp.KeyUpdates)
	log.Printf("Query: %+v\n", queryKeyUpdatesResp.Query)
	log.Printf("Cursor: %+v\n", queryKeyUpdatesResp.Cursor)
	log.Printf("Error: %+v\n", queryKeyUpdatesResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.QueryKeyUpdates
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"contentType": "text/plain",
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "DESC",
		"orderField": "createdTime",
		"scope": "internal"
	}
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const keyUpdatesService = new KeyUpdatesService(client);

// QueryKeyUpdates gets a list of key updates with pagination support.
const keyUpdatesServiceResp = await keyUpdatesService.queryKeyUpdates({
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"contentType": "text/plain",
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "DESC",
		"orderField": "createdTime",
		"scope": "internal"
	}
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response
console.info({"keyUpdates", keyUpdatesServiceResp.data.keyUpdates});
console.info({"query", keyUpdatesServiceResp.data.query});
console.info({"cursor", keyUpdatesServiceResp.data.cursor});

QueryKeyUpdatesResponse

A 200 response with an empty error field indicates that the request was successful.

  • keyUpdates - array of KeyUpdate - KeyUpdates is the list of key updates matching the query.
  • query - KeyUpdatesQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"error": "something went wrong",
	"keyUpdates": [
		{
			"color": "#000000",
			"content": "Database connection pool exhaustion identified as root cause",
			"contentType": "text/plain",
			"createdBy": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"createdTime": "2021-08-07T11:58:23Z",
			"id": "keyupdate-123",
			"incidentID": "incident-123",
			"lastModifiedBy": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"modifiedTime": "2021-08-07T11:58:23Z",
			"orgID": "org-123",
			"scope": "internal",
			"severityID": "severity-123",
			"statusID": "status-123",
			"title": "Root cause identified"
		},
		{
			"color": "#000000",
			"content": "Database connection pool exhaustion identified as root cause",
			"contentType": "text/plain",
			"createdBy": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"createdTime": "2021-08-07T11:58:23Z",
			"id": "keyupdate-123",
			"incidentID": "incident-123",
			"lastModifiedBy": {
				"name": "Morty Smith",
				"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
				"userID": "user-123"
			},
			"modifiedTime": "2021-08-07T11:58:23Z",
			"orgID": "org-123",
			"scope": "internal",
			"severityID": "severity-123",
			"statusID": "status-123",
			"title": "Root cause identified"
		}
	],
	"query": {
		"contentType": "text/plain",
		"incidentID": "incident-123",
		"limit": 10,
		"orderDirection": "DESC",
		"orderField": "createdTime",
		"scope": "internal"
	}
}

UpdateKeyUpdate

UpdateKeyUpdate modifies an existing key update.

UpdateKeyUpdateRequest

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • id - string - ID is the identifier of the key update to modify. Is Required.
  • title - string - Title is the new title for the key update.
  • content - string - Content is the new content for the key update. Is Required. Maximum length: 65536.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the format of the content. Is Required.
  • statusID - string - StatusID references the incident status at the time of this update.
  • severityID - string - SeverityID references the incident severity at the time of this update.
  • scope - string - options: "internal" "public" "private" - Scope specifies the audience or visibility of this key update.
  • color - string - Color is the color of the key update.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.UpdateKeyUpdate" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"color": "#000000",
	"content": "Database connection pool exhaustion identified and fixed",
	"contentType": "text/plain",
	"id": "keyupdate-123",
	"incidentID": "incident-123",
	"scope": "internal",
	"severityID": "severity-123",
	"statusID": "status-123",
	"title": "Root cause identified and mitigated"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	keyUpdatesService := incident.NewKeyUpdatesService(client)
	// make the request...
	updateKeyUpdateResp, err := keyUpdatesService.UpdateKeyUpdate(ctx, main.UpdateKeyUpdateRequest{
		IncidentID: "incident-123",
		ID: "keyupdate-123",
		Title: "Root cause identified and mitigated",
		Content: "Database connection pool exhaustion identified and fixed",
		ContentType: "text/plain",
		StatusID: "status-123",
		SeverityID: "severity-123",
		Scope: "internal",
		Color: "#000000",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("KeyUpdate: %+v\n", updateKeyUpdateResp.KeyUpdate)
	log.Printf("Error: %+v\n", updateKeyUpdateResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/KeyUpdatesService.UpdateKeyUpdate
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"color": "#000000",
	"content": "Database connection pool exhaustion identified and fixed",
	"contentType": "text/plain",
	"id": "keyupdate-123",
	"incidentID": "incident-123",
	"scope": "internal",
	"severityID": "severity-123",
	"statusID": "status-123",
	"title": "Root cause identified and mitigated"
}
JavaScript
import { GrafanaIncidentClient, KeyUpdatesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const keyUpdatesService = new KeyUpdatesService(client);

// UpdateKeyUpdate modifies an existing key update.
const keyUpdatesServiceResp = await keyUpdatesService.updateKeyUpdate({
	"color": "#000000",
	"content": "Database connection pool exhaustion identified and fixed",
	"contentType": "text/plain",
	"id": "keyupdate-123",
	"incidentID": "incident-123",
	"scope": "internal",
	"severityID": "severity-123",
	"statusID": "status-123",
	"title": "Root cause identified and mitigated"
});

if (!keyUpdatesServiceResp.success) {
  // handle the error
  throw new Error(keyUpdatesServiceResp.error);
}

// access the fields of the response
console.info({"keyUpdate", keyUpdatesServiceResp.data.keyUpdate});

UpdateKeyUpdateResponse

A 200 response with an empty error field indicates that the request was successful.

  • keyUpdate - KeyUpdate - KeyUpdate is the modified key update.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"keyUpdate": {
		"color": "#000000",
		"content": "Database connection pool exhaustion identified as root cause",
		"contentType": "text/plain",
		"createdBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2021-08-07T11:58:23Z",
		"id": "keyupdate-123",
		"incidentID": "incident-123",
		"lastModifiedBy": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"modifiedTime": "2021-08-07T11:58:23Z",
		"orgID": "org-123",
		"scope": "internal",
		"severityID": "severity-123",
		"statusID": "status-123",
		"title": "Root cause identified"
	}
}

RolesService

RolesService defines the interface for interacting with roles, providing CRUD operations and more features related to roles.

ArchiveRole

ArchiveRole archives a role.

ArchiveRoleRequest

  • roleID - number - Role to be archived to the organization
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.ArchiveRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"roleID": 1
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	rolesService := incident.NewRolesService(client)
	// make the request...
	archiveRoleResp, err := rolesService.ArchiveRole(ctx, main.ArchiveRoleRequest{
		RoleID: 1,
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", archiveRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.ArchiveRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"roleID": 1
}
JavaScript
import { GrafanaIncidentClient, RolesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const rolesService = new RolesService(client);

// ArchiveRole archives a role.
const rolesServiceResp = await rolesService.archiveRole({
  roleID: 1,
});

if (!rolesServiceResp.success) {
  // handle the error
  throw new Error(rolesServiceResp.error);
}

// access the fields of the response

ArchiveRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

CreateRole

CreateRole creates a role.

CreateRoleRequest

  • role - Role - Role to be created to the organization
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.CreateRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	rolesService := incident.NewRolesService(client)
	// make the request...
	createRoleResp, err := rolesService.CreateRole(ctx, main.CreateRoleRequest{
		Role: main.Role{
			RoleID: 1,
			OrgID: "org-1",
			Name: "commander",
			Description: "The commander is the incident commander.",
			Important: true,
			Mandatory: true,
			Archived: true,
			CreatedAt: "2020-01-01T00:00:00Z",
			UpdatedAt: "2020-01-01T00:00:00Z",
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Role: %+v\n", createRoleResp.Role)
	log.Printf("Error: %+v\n", createRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.CreateRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
}
JavaScript
import { GrafanaIncidentClient, RolesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const rolesService = new RolesService(client);

// CreateRole creates a role.
const rolesServiceResp = await rolesService.createRole({
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
});

if (!rolesServiceResp.success) {
  // handle the error
  throw new Error(rolesServiceResp.error);
}

// access the fields of the response
console.info({"role", rolesServiceResp.data.role});

CreateRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • role - Role - Role is the newly created role.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
}

DeleteRole

DeleteRole deletes a role.

DeleteRoleRequest

  • roleID - number - Role to be deleted to the organization
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.DeleteRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"roleID": 1
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	rolesService := incident.NewRolesService(client)
	// make the request...
	deleteRoleResp, err := rolesService.DeleteRole(ctx, main.DeleteRoleRequest{
		RoleID: 1,
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", deleteRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.DeleteRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"roleID": 1
}
JavaScript
import { GrafanaIncidentClient, RolesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const rolesService = new RolesService(client);

// DeleteRole deletes a role.
const rolesServiceResp = await rolesService.deleteRole({
  roleID: 1,
});

if (!rolesServiceResp.success) {
  // handle the error
  throw new Error(rolesServiceResp.error);
}

// access the fields of the response

DeleteRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

GetRoles

GetRoles gets all roles.

GetRolesRequest

  • No fields
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.GetRoles" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	rolesService := incident.NewRolesService(client)
	// make the request...
	getRolesResp, err := rolesService.GetRoles(ctx, main.GetRolesRequest{
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Roles: %+v\n", getRolesResp.Roles)
	log.Printf("Error: %+v\n", getRolesResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.GetRoles
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{}
JavaScript
import { GrafanaIncidentClient, RolesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const rolesService = new RolesService(client);

// GetRoles gets all roles.
const rolesServiceResp = await rolesService.getRoles({});

if (!rolesServiceResp.success) {
  // handle the error
  throw new Error(rolesServiceResp.error);
}

// access the fields of the response
console.info({"roles", rolesServiceResp.data.roles});

GetRolesResponse

A 200 response with an empty error field indicates that the request was successful.

  • roles - array of Role - Roles is the list of roles.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"roles": [
		{
			"archived": true,
			"createdAt": "2020-01-01T00:00:00Z",
			"description": "The commander is the incident commander.",
			"important": true,
			"mandatory": true,
			"name": "commander",
			"orgID": "org-1",
			"roleID": 1,
			"updatedAt": "2020-01-01T00:00:00Z"
		},
		{
			"archived": true,
			"createdAt": "2020-01-01T00:00:00Z",
			"description": "The commander is the incident commander.",
			"important": true,
			"mandatory": true,
			"name": "commander",
			"orgID": "org-1",
			"roleID": 1,
			"updatedAt": "2020-01-01T00:00:00Z"
		}
	]
}

UnarchiveRole

UnarchiveRole unarchives a role.

UnarchiveRoleRequest

  • roleID - number - Role to be unarchived to the organization
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.UnarchiveRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"roleID": 1
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	rolesService := incident.NewRolesService(client)
	// make the request...
	unarchiveRoleResp, err := rolesService.UnarchiveRole(ctx, main.UnarchiveRoleRequest{
		RoleID: 1,
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Error: %+v\n", unarchiveRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.UnarchiveRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"roleID": 1
}
JavaScript
import { GrafanaIncidentClient, RolesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient('https://your-stack.grafana.net', serviceAccountToken);
const rolesService = new RolesService(client);

// UnarchiveRole unarchives a role.
const rolesServiceResp = await rolesService.unarchiveRole({
  roleID: 1,
});

if (!rolesServiceResp.success) {
  // handle the error
  throw new Error(rolesServiceResp.error);
}

// access the fields of the response

UnarchiveRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong"
}

UpdateRole

UpdateRole updates a role.

UpdateRoleRequest

  • role - Role - Role to be updated to the organization
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.UpdateRole" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	rolesService := incident.NewRolesService(client)
	// make the request...
	updateRoleResp, err := rolesService.UpdateRole(ctx, main.UpdateRoleRequest{
		Role: main.Role{
			RoleID: 1,
			OrgID: "org-1",
			Name: "commander",
			Description: "The commander is the incident commander.",
			Important: true,
			Mandatory: true,
			Archived: true,
			CreatedAt: "2020-01-01T00:00:00Z",
			UpdatedAt: "2020-01-01T00:00:00Z",
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Role: %+v\n", updateRoleResp.Role)
	log.Printf("Error: %+v\n", updateRoleResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/RolesService.UpdateRole
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
}
JavaScript
import { GrafanaIncidentClient, RolesService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const rolesService = new RolesService(client);

// UpdateRole updates a role.
const rolesServiceResp = await rolesService.updateRole({
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
});

if (!rolesServiceResp.success) {
  // handle the error
  throw new Error(rolesServiceResp.error);
}

// access the fields of the response
console.info({"role", rolesServiceResp.data.role});

UpdateRoleResponse

A 200 response with an empty error field indicates that the request was successful.

  • role - Role - Role is the newly updated role.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"role": {
		"archived": true,
		"createdAt": "2020-01-01T00:00:00Z",
		"description": "The commander is the incident commander.",
		"important": true,
		"mandatory": true,
		"name": "commander",
		"orgID": "org-1",
		"roleID": 1,
		"updatedAt": "2020-01-01T00:00:00Z"
	}
}

TasksService

TasksService provides methods for managing tasks relating to Incidents.

  • AddTask - AddTask adds a task to an Incident.
  • DeleteTask - DeleteTask deletes a task.
  • UpdateTaskStatus - UpdateTaskStatus updates the task's Status.
  • UpdateTaskText - UpdateTaskText updates the task's text.
  • UpdateTaskUser - UpdateTaskUser updates the task's assigned user. Passing an empty user ID will clear the assigned user.

AddTask

AddTask adds a task to an Incident.

AddTaskRequest

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • text - string - Text is the todo item. Is Required. Maximum length: 65536.
  • assignToUserID - string - AssignToUserId is the user the task will be assigned to
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.AddTask" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"assignToUserID": "User123",
	"incidentID": "incident-123456",
	"text": "Assign an investigator"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	tasksService := incident.NewTasksService(client)
	// make the request...
	addTaskResp, err := tasksService.AddTask(ctx, main.AddTaskRequest{
		IncidentID: "incident-123456",
		Text: "Assign an investigator",
		AssignToUserId: "User123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("IncidentID: %+v\n", addTaskResp.IncidentID)
	log.Printf("Task: %+v\n", addTaskResp.Task)
	log.Printf("TaskList: %+v\n", addTaskResp.TaskList)
	log.Printf("Error: %+v\n", addTaskResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.AddTask
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"assignToUserID": "User123",
	"incidentID": "incident-123456",
	"text": "Assign an investigator"
}
JavaScript
import { GrafanaIncidentClient, TasksService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const tasksService = new TasksService(client);

// AddTask adds a task to an Incident.
const tasksServiceResp = await tasksService.addTask({
	"assignToUserID": "User123",
	"incidentID": "incident-123456",
	"text": "Assign an investigator"
});

if (!tasksServiceResp.success) {
  // handle the error
  throw new Error(tasksServiceResp.error);
}

// access the fields of the response
console.info({"incidentID", tasksServiceResp.data.incidentID});
console.info({"task", tasksServiceResp.data.task});
console.info({"taskList", tasksServiceResp.data.taskList});

AddTaskResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to. Is Required.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incidentID": "incident-123456",
	"task": {
		"assignedUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"authorUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2018-01-01T00:00:00Z",
		"immutable": true,
		"modifiedTime": "2018-01-01T00:00:00Z",
		"status": "todo",
		"taskID": "task-123456",
		"text": "Assign an investigator"
	},
	"taskList": {
		"doneCount": 8,
		"tasks": [
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			},
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			}
		],
		"todoCount": 5
	}
}

DeleteTask

DeleteTask deletes a task.

DeleteTaskRequest

  • incidentID - string - IncidentID is the ID of the Incident. Is Required.
  • taskID - string - TaskID is the ID of the task. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.DeleteTask" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "inccident-123456",
	"taskID": "task-123456"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	tasksService := incident.NewTasksService(client)
	// make the request...
	deleteTaskResp, err := tasksService.DeleteTask(ctx, main.DeleteTaskRequest{
		IncidentID: "inccident-123456",
		TaskID: "task-123456",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("IncidentID: %+v\n", deleteTaskResp.IncidentID)
	log.Printf("TaskList: %+v\n", deleteTaskResp.TaskList)
	log.Printf("Error: %+v\n", deleteTaskResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.DeleteTask
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "inccident-123456",
	"taskID": "task-123456"
}
JavaScript
import { GrafanaIncidentClient, TasksService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const tasksService = new TasksService(client);

// DeleteTask deletes a task.
const tasksServiceResp = await tasksService.deleteTask({
	"incidentID": "inccident-123456",
	"taskID": "task-123456"
});

if (!tasksServiceResp.success) {
  // handle the error
  throw new Error(tasksServiceResp.error);
}

// access the fields of the response
console.info({"incidentID", tasksServiceResp.data.incidentID});
console.info({"taskList", tasksServiceResp.data.taskList});

DeleteTaskResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incidentID": "incident-123456",
	"taskList": {
		"doneCount": 8,
		"tasks": [
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			},
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			}
		],
		"todoCount": 5
	}
}

UpdateTaskStatus

UpdateTaskStatus updates the task's Status.

UpdateTaskStatusRequest

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • taskID - string - TaskID is the ID of the Task to update. Is Required.
  • status - string - options: "todo" "progress" "done" - Status is the new status of this task. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.UpdateTaskStatus" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123456",
	"status": "todo",
	"taskID": "task-12345"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	tasksService := incident.NewTasksService(client)
	// make the request...
	updateTaskStatusResp, err := tasksService.UpdateTaskStatus(ctx, main.UpdateTaskStatusRequest{
		IncidentID: "incident-123456",
		TaskID: "task-12345",
		Status: "todo",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("IncidentID: %+v\n", updateTaskStatusResp.IncidentID)
	log.Printf("Task: %+v\n", updateTaskStatusResp.Task)
	log.Printf("TaskList: %+v\n", updateTaskStatusResp.TaskList)
	log.Printf("Error: %+v\n", updateTaskStatusResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.UpdateTaskStatus
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123456",
	"status": "todo",
	"taskID": "task-12345"
}
JavaScript
import { GrafanaIncidentClient, TasksService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const tasksService = new TasksService(client);

// UpdateTaskStatus updates the task's Status.
const tasksServiceResp = await tasksService.updateTaskStatus({
	"incidentID": "incident-123456",
	"status": "todo",
	"taskID": "task-12345"
});

if (!tasksServiceResp.success) {
  // handle the error
  throw new Error(tasksServiceResp.error);
}

// access the fields of the response
console.info({"incidentID", tasksServiceResp.data.incidentID});
console.info({"task", tasksServiceResp.data.task});
console.info({"taskList", tasksServiceResp.data.taskList});

UpdateTaskStatusResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incidentID": "incident-123456",
	"task": {
		"assignedUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"authorUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2018-01-01T00:00:00Z",
		"immutable": true,
		"modifiedTime": "2018-01-01T00:00:00Z",
		"status": "todo",
		"taskID": "task-123456",
		"text": "Assign an investigator"
	},
	"taskList": {
		"doneCount": 8,
		"tasks": [
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			},
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			}
		],
		"todoCount": 5
	}
}

UpdateTaskText

UpdateTaskText updates the task's text.

UpdateTaskTextRequest

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • taskID - string - TaskID is the ID of the task. Is Required.
  • text - string - Text is the string that describes the Task. Maximum length: 65536.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.UpdateTaskText" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123456",
	"taskID": "task-123456",
	"text": "Check the logs"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	tasksService := incident.NewTasksService(client)
	// make the request...
	updateTaskTextResp, err := tasksService.UpdateTaskText(ctx, main.UpdateTaskTextRequest{
		IncidentID: "incident-123456",
		TaskID: "task-123456",
		Text: "Check the logs",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("IncidentID: %+v\n", updateTaskTextResp.IncidentID)
	log.Printf("Task: %+v\n", updateTaskTextResp.Task)
	log.Printf("TaskList: %+v\n", updateTaskTextResp.TaskList)
	log.Printf("Error: %+v\n", updateTaskTextResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.UpdateTaskText
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123456",
	"taskID": "task-123456",
	"text": "Check the logs"
}
JavaScript
import { GrafanaIncidentClient, TasksService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const tasksService = new TasksService(client);

// UpdateTaskText updates the task's text.
const tasksServiceResp = await tasksService.updateTaskText({
	"incidentID": "incident-123456",
	"taskID": "task-123456",
	"text": "Check the logs"
});

if (!tasksServiceResp.success) {
  // handle the error
  throw new Error(tasksServiceResp.error);
}

// access the fields of the response
console.info({"incidentID", tasksServiceResp.data.incidentID});
console.info({"task", tasksServiceResp.data.task});
console.info({"taskList", tasksServiceResp.data.taskList});

UpdateTaskTextResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incidentID": "incident-123456",
	"task": {
		"assignedUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"authorUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2018-01-01T00:00:00Z",
		"immutable": true,
		"modifiedTime": "2018-01-01T00:00:00Z",
		"status": "todo",
		"taskID": "task-123456",
		"text": "Assign an investigator"
	},
	"taskList": {
		"doneCount": 8,
		"tasks": [
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			},
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			}
		],
		"todoCount": 5
	}
}

UpdateTaskUser

UpdateTaskUser updates the task's assigned user. Passing an empty user ID will clear the assigned user.

UpdateTaskUserRequest

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • taskID - string - TaskID is the ID of the Task to update. Is Required.
  • userID - string - UserID is the ID of the User to assign to the Task.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.UpdateTaskUser" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"incidentID": "incident-123456",
	"taskID": "task-12345",
	"userID": "user-id"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	tasksService := incident.NewTasksService(client)
	// make the request...
	updateTaskUserResp, err := tasksService.UpdateTaskUser(ctx, main.UpdateTaskUserRequest{
		IncidentID: "incident-123456",
		TaskID: "task-12345",
		UserID: "user-id",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("IncidentID: %+v\n", updateTaskUserResp.IncidentID)
	log.Printf("Task: %+v\n", updateTaskUserResp.Task)
	log.Printf("TaskList: %+v\n", updateTaskUserResp.TaskList)
	log.Printf("Error: %+v\n", updateTaskUserResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/TasksService.UpdateTaskUser
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"incidentID": "incident-123456",
	"taskID": "task-12345",
	"userID": "user-id"
}
JavaScript
import { GrafanaIncidentClient, TasksService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const tasksService = new TasksService(client);

// UpdateTaskUser updates the task's assigned user.
Passing an empty user ID will clear the assigned user.
const tasksServiceResp = await tasksService.updateTaskUser({
	"incidentID": "incident-123456",
	"taskID": "task-12345",
	"userID": "user-id"
});

if (!tasksServiceResp.success) {
  // handle the error
  throw new Error(tasksServiceResp.error);
}

// access the fields of the response
console.info({"incidentID", tasksServiceResp.data.incidentID});
console.info({"task", tasksServiceResp.data.task});
console.info({"taskList", tasksServiceResp.data.taskList});

UpdateTaskUserResponse

A 200 response with an empty error field indicates that the request was successful.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to. Is Required.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"incidentID": "incident-123456",
	"task": {
		"assignedUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"authorUser": {
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"userID": "user-123"
		},
		"createdTime": "2018-01-01T00:00:00Z",
		"immutable": true,
		"modifiedTime": "2018-01-01T00:00:00Z",
		"status": "todo",
		"taskID": "task-123456",
		"text": "Assign an investigator"
	},
	"taskList": {
		"doneCount": 8,
		"tasks": [
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			},
			{
				"assignedUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"authorUser": {
					"name": "Morty Smith",
					"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
					"userID": "user-123"
				},
				"createdTime": "2018-01-01T00:00:00Z",
				"immutable": true,
				"modifiedTime": "2018-01-01T00:00:00Z",
				"status": "todo",
				"taskID": "task-123456",
				"text": "Assign an investigator"
			}
		],
		"todoCount": 5
	}
}

UsersService

UsersService provides services related to people in the system.

  • GetUser - GetUser returns the information about a specific user.
  • QueryUsers - QueryUsers gets a list of users.

GetUser

GetUser returns the information about a specific user.

GetUserRequest

  • userID - string - UserID is the user ID to find the user for. All ids are in the format “provider:user-id” which allows you to refer to users from different providers. “grafana-incident:” is preferred, but all are accepted. Is Required.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/UsersService.GetUser" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"userID": "grafana-incident:123"
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	usersService := incident.NewUsersService(client)
	// make the request...
	getUserResp, err := usersService.GetUser(ctx, main.GetUserRequest{
		UserID: "grafana-incident:123",
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("User: %+v\n", getUserResp.User)
	log.Printf("Error: %+v\n", getUserResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/UsersService.GetUser
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"userID": "grafana-incident:123"
}
JavaScript
import { GrafanaIncidentClient, UsersService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const usersService = new UsersService(client);

// GetUser returns the information about a specific user.
const usersServiceResp = await usersService.getUser({
	"userID": "grafana-incident:123"
});

if (!usersServiceResp.success) {
  // handle the error
  throw new Error(usersServiceResp.error);
}

// access the fields of the response
console.info({"user", usersServiceResp.data.user});

GetUserResponse

A 200 response with an empty error field indicates that the request was successful.

  • user - User - User is the user
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"error": "something went wrong",
	"user": {
		"email": "you@company.com",
		"grafanaLogin": "admin",
		"grafanaUserID": "123",
		"internalUserID": "user-12345",
		"modifiedTime": "2021-08-07T11:58:23Z",
		"msTeamsUserID": "26e2b619-b955-483f-a519-c8950aacbaa9",
		"name": "Morty Smith",
		"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
		"slackTeamID": "DEF123456",
		"slackUserID": "ABC123456",
		"userID": "grafana-incident:123"
	}
}

QueryUsers

QueryUsers gets a list of users.

QueryUsersRequest

  • query - UsersQuery - Query describes the query to make
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
curl
curl "https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/UsersService.QueryUsers" \
  --request POST \
  --header 'Content-Type: application/json; charset=utf-8' \
  --header 'Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...' \
  --data '{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"limit": 10
	}
}'
Go
package main

import (
	"context"
	"fmt"
	"log"
	"os"

	incident "github.com/grafana/incident-go"
)

func main() {
	ctx := context.Background()
	// create a client, and required services...
	serviceAccountToken := os.Getenv("SERVICE_ACCOUNT_TOKEN")
	client := incident.NewClient("https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1", serviceAccountToken)
	usersService := incident.NewUsersService(client)
	// make the request...
	queryUsersResp, err := usersService.QueryUsers(ctx, main.QueryUsersRequest{
		Query: main.UsersQuery{
			Limit: 10,
		},
		Cursor: main.Cursor{
			NextValue: "123e4567-e89b-12d3-a456-426614174000",
			HasMore: true,
		},
	})
	if err != nil {
		// something went wrong
		fmt.Errorf(os.Stderr, "%s\n", err)
		os.Exit(1)
	}
	// use the output fields...
	log.Printf("Users: %+v\n", queryUsersResp.Users)
	log.Printf("Query: %+v\n", queryUsersResp.Query)
	log.Printf("Cursor: %+v\n", queryUsersResp.Cursor)
	log.Printf("Error: %+v\n", queryUsersResp.Error)

}
JSON
POST https://your-stack.grafana.net/api/plugins/grafana-irm-app/resources/api/v1/UsersService.QueryUsers
Content-Type="application/json; charset=utf-8"
Authorization: Bearer glsa_HOruNAb7SOiCdshU9algkrq7F...

{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"limit": 10
	}
}
JavaScript
import { GrafanaIncidentClient, UsersService } from '@grafana/incident-node';

// https://grafana.com/docs/grafana-cloud/incident/api/auth/#get-a-service-account-token
const serviceAccountToken = process.env.GRAFANA_CLOUD_SERVICE_ACCOUNT_TOKEN;
const client = new GrafanaIncidentClient(
  "https://your-stack.grafana.net",
  serviceAccountToken
);
const usersService = new UsersService(client);

// QueryUsers gets a list of users.
const usersServiceResp = await usersService.queryUsers({
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"query": {
		"limit": 10
	}
});

if (!usersServiceResp.success) {
  // handle the error
  throw new Error(usersServiceResp.error);
}

// access the fields of the response
console.info({"users", usersServiceResp.data.users});
console.info({"query", usersServiceResp.data.query});
console.info({"cursor", usersServiceResp.data.cursor});

QueryUsersResponse

A 200 response with an empty error field indicates that the request was successful.

  • users - array of User - Users is a list of Users.
  • query - UsersQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.
JSON
{
	"cursor": {
		"hasMore": true,
		"nextValue": "123e4567-e89b-12d3-a456-426614174000"
	},
	"error": "something went wrong",
	"query": {
		"limit": 10
	},
	"users": [
		{
			"email": "you@company.com",
			"grafanaLogin": "admin",
			"grafanaUserID": "123",
			"internalUserID": "user-12345",
			"modifiedTime": "2021-08-07T11:58:23Z",
			"msTeamsUserID": "26e2b619-b955-483f-a519-c8950aacbaa9",
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"slackTeamID": "DEF123456",
			"slackUserID": "ABC123456",
			"userID": "grafana-incident:123"
		},
		{
			"email": "you@company.com",
			"grafanaLogin": "admin",
			"grafanaUserID": "123",
			"internalUserID": "user-12345",
			"modifiedTime": "2021-08-07T11:58:23Z",
			"msTeamsUserID": "26e2b619-b955-483f-a519-c8950aacbaa9",
			"name": "Morty Smith",
			"photoURL": "https://upload.wikimedia.org/wikipedia/en/c/c3/Morty_Smith.png",
			"slackTeamID": "DEF123456",
			"slackUserID": "ABC123456",
			"userID": "grafana-incident:123"
		}
	]
}

Objects

Various other structures (objects) are described throughout the API reference, and a complete list of them is included here. They included the various Request and Response pairs for each method.

  • ActivityItem - ActivityItem describes an event that occurred related to an Incident.
  • ActivityQuery - ActivityQuery is the response from the QueryActivity method.
  • Assignment - Relation between a User and a Role inside the incident
  • AssignmentPreview - AssignmentPreview describes a person assigned to an incident without the Role object.
  • Attachment - Attachment is a file attached to something.
  • Cursor - Cursor describes the position in a result set. It is passed back into the same API to get the next page of results.
  • CustomMetadataField - CustomMetadataField is a custom metadata field.
  • CustomMetadataFieldSelectOption - CustomMetadataFieldSelectOption is a select option for a select field.
  • CustomMetadataFieldValue - CustomMetadataFieldValue is a custom metadata field value.
  • EnabledHook - EnabledHook is a Hook that has been wired up to an event.
  • Field - Field represents a key/value pair, with additional metadata. Fields are used to represent dynamic data structures.
  • FieldValue - FieldValue represents a record with a field and its value.
  • GetHomescreenVersionRequest - GetHomescreenVersionRequest is the request for the GetHomescreenVersion method.
  • GetHomescreenVersionResponse - GetHomescreenVersionResponse is the response for the GetHomescreenVersion method.
  • GetIncidentVersionRequest - GetIncidentVersionRequest is the request for the GetIncidentVersion method.
  • GetIncidentVersionResponse - GetIncidentVersionResponse is the response for the GetIncidentVersion method.
  • Hook - Hook describes an updatable method that may be wired up to events.
  • HookConfig - HookConfig holds configuration fields for a Hook.
  • HookMetadata - HookMetadata contains metadata about the Run and Update of a Hook.
  • HookRun - HookRun describes the result of executing a Hook.
  • Incident - Incident is a single incident.
  • IncidentKeyValueLabel - IncidentKeyValueLabel is a key:value label associated with an Incident.
  • IncidentLabel - IncidentLabel is a label associated with an Incident.
  • IncidentMembership - IncidentMembership represents a list of people involved in an Incident.
  • IncidentMembershipPreview - IncidentMembershipPreview is a summary of the people involved in an Incident.
  • IncidentPreview - IncidentPreview is a minimal preview of a full Incident (omitting structured children) meant for lightweight listings or getting basic metadata.
  • IncidentPreviewsQuery - IncidentPreviewsQuery describes the query to make.
  • IncidentRef - IncidentRef represents a reference to a third-party system.
  • IncidentsQuery - IncidentsQuery is the query for the QueryIncidentsRequest.
  • IncomingWebhookResponse - IncomingWebhookResponse is the response sent back to the webhook caller when an incoming webhook has been received.
  • KeyUpdate - KeyUpdate represents a significant update or milestone in an incident’s lifecycle.
  • KeyUpdatesQuery - KeyUpdatesQuery describes the query parameters for listing key updates.
  • OutgoingWebhookPayload - OutgoingWebhookPayload represents the webhook HTTP POST body and contains metadata for the webhook.
  • Role - Role represents a role that will be used to assign people in the incident.
  • Task - Task is an individual task that somebody will do to resolve an Incident.
  • TaskList - TaskList is a list of tasks.
  • User - User contains the details of a person.
  • UserPreview - UserPreview is a user involved in an Incident.
  • UsersQuery - UsersQuery is the request for getting a list of users.

ActivityItem

ActivityItem describes an event that occurred related to an Incident.

  • activityItemID - string - The unique identifier of the ActivityItem.
  • incidentID - string - IncidentID is the unique identifier of the Incident.
  • user - UserPreview - User is the person who caused the ActivityItem.
  • subjectUser - UserPreview - SubjectUser is the person who was affected by the ActivityItem (not the person who caused it).
  • createdTime - string - CreatedTime is the time when the ActivityItem was created. The string value format should follow RFC 3339.
  • eventTime - string - EventTime is the time when the event occurred. It is configurable by the user. The string value format should follow RFC 3339.
  • activityKind - string - options: "incidentUpdated" "incidentTitleChanged" "incidentStatusChanged" "incidentSeverityChanged" "incidentCreated" "incidentDeleted" "incidentClosed" "roleAssigned" "roleUnassigned" "actionRun" "userNote" "dataQuery" "hookRunMetadata" "taskAdded" "taskUpdated" "taskCompleted" "taskDeleted" "messageReaction" "contextAttached" "incidentIsDrillChanged" "incidentStart" "incidentEnd" "incidentSummary" "labelAdded" "labelRemoved" "siftResult" - ActivityKind is the type of activity this item represents.
  • body - string - Body is a human readable description of the ActivityItem. Maximum length: 65536.
  • url - string - URL is an url related with this activity Maximum length: 2048.
  • tags - array of string - Tags contains a list of tags associated with this activity.
  • immutable - boolean - Immutable indicates if the activity is immutable.
  • fieldValues - object - FieldValues is an object of field values associated with the ActivityItem. The structure is determined by the ActivityKind.
  • attachments - array of Attachment - Attachments is a list of files attached to this item.
  • relevance - string - options: "automatic" "archive" "low" "normal" "high" - Relevance is the preferred relevance of the activity item. if set to ‘automatic’ (the default), the relevance will be guessed automatically. Is Required.

ActivityQuery

ActivityQuery is the response from the QueryActivity method.

  • incidentID - string - IncidentID is the unique identifier of the Incident.
  • limit - number - Limit is the number of Incidents to return. Is Required. Maximum value: 100.
  • tag - string - Tag is the tag to filter by.
  • orderDirection - string - options: "ASC" "DESC" - OrderDirection is the direction to order the results. Is Required.
  • activityKind - array of string - ActivityKind filters by a list of allowed ActivityKind’s.

AddActivityRequest

AddActivityRequest is the request for the AddActivity method.

  • incidentID - string - IncidentID is the unique identifier of the Incident. Is Required.
  • activityKind - string - options: "userNote" - ActivityKind is the type of activity this item represents. Is Required.
  • body - string - Body is a human readable description of the ActivityItem. URLs mentioned will be parsed and attached as context. Is Required. Maximum length: 65536.
  • fieldValues - object - FieldValues is an object of field values associated with the ActivityItem. The structure is determined by the ActivityKind.
  • eventTime - string - EventTime is the time when the event occurred. If empty, the current time is used. The string value format should follow RFC 3339.

AddActivityResponse

AddActivityResponse is the response from the AddActivity method.

  • activityItem - ActivityItem - ActivityItem is the newly created ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AddFieldRequest

AddFieldRequest is the request struct for api AddField method.

AddFieldResponse

AddFieldResponse is the response from the AddField method.

  • field - CustomMetadataField - Field is the field that was added.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AddFieldSelectOptionRequest

AddFieldSelectOptionRequest is the request struct for AddFieldSelectOption method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
  • fieldSelectOption - CustomMetadataFieldSelectOption - FieldSelectOption is the new field select option.

AddFieldSelectOptionResponse

AddFieldSelectOptionResponse is the response from the AddFieldSelectOption method.

  • fieldSelectOptionUUID - string - FieldSelectOptionUUID is the UUID of the field select option that was added.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AddLabelKeyRequest

AddLabelKeyRequest is the request for the AddLabelKey method.

  • key - string - Key is the label key.
  • description - string - Description is a short explanation of the label.
  • colorHex - string - Color is the CSS hex color of the label. Labels show up in both light and dark modes, and this should be taken into consideration when selecting a color.

AddLabelKeyResponse

AddLabelKeyResponse is the response for the AddLabelKey method.

  • field - CustomMetadataField - Field is the field that was added.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AddLabelRequest

AddLabelRequest is the request for the AddLabel method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • label - IncidentLabel - Label is the new label of the Incident.

AddLabelResponse

AddLabelResponse is the response for the AddLabel method.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AddLabelValueRequest

AddLabelValueRequest is the request for the AddLabelValue method.

  • key - string - Key is the label key.
  • value - string - Value is the label value.
  • description - string - Description is a short explanation of the label value.
  • colorHex - string - Color is the CSS hex color of the label value. Labels show up in both light and dark modes, and this should be taken into consideration when selecting a color.

AddLabelValueResponse

AddLabelValueResponse is the response for the AddLabelValue method.

  • field - CustomMetadataField - Field is the field that was updated.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AddTaskRequest

AddTaskRequest is the request for the AddTask method.

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • text - string - Text is the todo item. Is Required. Maximum length: 65536.
  • assignToUserID - string - AssignToUserId is the user the task will be assigned to

AddTaskResponse

AddTaskResponse is the response from the AddTask method.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to. Is Required.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

ArchiveFieldRequest

ArchiveFieldRequest is the request struct for api ArchiveField method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.

ArchiveFieldResponse

ArchiveFieldResponse is the response from the ArchiveField method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

ArchiveRoleRequest

ArchiveRoleRequest is the request to archive a role.

  • roleID - number - Role to be archived to the organization

ArchiveRoleResponse

ArchiveRoleResponse is the response to archive a role.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AssignLabelByUUIDRequest

AssignLabelByUUIDRequest is the request for the AssignLabelByUUID method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • keyUUID - string - KeyUUID is the label key uuid. Is Required.
  • valueUUID - string - ValueUUID is the UUID of the label value. Is Required.

AssignLabelByUUIDResponse

AssignLabelByUUIDResponse is the response from the AssignLabelByUUID method.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AssignLabelRequest

AssignLabelRequest is the request for the AssignLabel method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • key - string - Key is the label key. Is Required.
  • value - string - Value is the value of the label. Is Required.

AssignLabelResponse

AssignLabelResponse is the response from the AssignLabel method.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

AssignRoleRequest

AssignRoleRequest is the request for the AssignRole method.

  • incidentID - string - IncidentID is the identifier. Is Required.
  • userID - string - UserID is the identifier of the person to assign the role to. Is Required.
  • role - string - options: "commander" "investigator" "observer" - Role is the role of this person. Is Required.

AssignRoleResponse

AssignRoleResponse is the response for the AssignRole method.

  • incident - Incident - Incident is the Incident that was just updated.
  • didChange - boolean - DidChange indicates if the role was changed or not. If the role was already assigned, this will be false.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

Assignment

Relation between a User and a Role inside the incident

  • user - UserPreview - User is the person who holds this role.
  • role - Role - Role is the role string.
  • roleID - number - RoleID is the identifier of the role.

AssignmentPreview

AssignmentPreview describes a person assigned to an incident without the Role object.

  • user - UserPreview - User is the person who holds this role.
  • roleID - number - RoleID is the identifier of the role.

Attachment

Attachment is a file attached to something.

  • attachmentID - string - AttachmentID is the unique ID of this attachment.
  • attachedByUserID - string - AttachedByUserID is the ID of the user who attached this.
  • sourceURL - string - SourceURL is the URL of the file.
  • useSourceURL - boolean - UseSourceURL is true if the file should be downloaded from the source URL.
  • path - string - Path is the full path of the file.
  • uploadTime - string - UploadTime is the time the file was uploaded.
  • deletedTime - string - DeletedTime is the time the file was deleted. Empty string means the file hasn’t been deleted.
  • contentType - string - ContentType is the type of the file.
  • fileType - string - options: "file" "video" "image" "audio" "screenshare" - FileType is the type of file.
  • ext - string - Ext is the file extension.
  • contentLength - number - ContentLength is the ContentLength of the file in bytes.
  • displayType - string - options: "list" "embed" - DisplayType is how the file will be displayed.
  • downloadURL - string - DownloadURL for download
  • hasThumbnail - boolean - HasThumbnail is true if the file has a thumbnail.
  • thumbnailURL - string - ThumbnailURL for previews
  • sHA512 - string - SHA512 is the hash of the file contents.
  • attachmentErr - string - AttachmentErr is a string describing an error that occurred while processing the attachment.

CreateIncidentRequest

CreateIncidentRequest is the request for the CreateIncident method.

  • title - string - Title is the headline title of the Incident. Shorter the better, but should contain enough information to be able to identify and refer to this issue. Is Required.
  • severity - string - Severity expresses how bad the Incident is. Is Required.
  • labels - array of IncidentLabel - Labels are the labels associated with the Incident. Only the Label string is processed, the other fields are ignored.
  • roomPrefix - string - RoomPrefix is the prefix that will be used to create the Incident room. Is Required.
  • isDrill - boolean - IsDrill indicates if the Incident is a drill or not. Incidents that are drills do not show up in the dashboards, and may behave subtly differently in other ways too. For example, during drills, more help might be offered to users. Is Required.
  • status - string - options: "active" "resolved" - Status is the starting status of the Incident. Use “resolved” to open a retrospective incident. Is Required.
  • attachCaption - string - AttachCaption is the title of associated URL.
  • attachURL - string - AttachURLis the associated URL. Maximum length: 2048.
  • alertGroupID - string - AlertGroupID is the identifier of the alert group associated with this incident.

CreateIncidentResponse

CreateIncidentResponse is the response for the CreateIncident method.

  • incident - Incident - Incident is the Incident that was created.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

CreateKeyUpdateRequest

CreateKeyUpdateRequest is the request for the CreateKeyUpdate method.

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • title - string - Title is a short summary of the key update.
  • content - string - Content provides detailed information about the key update. Is Required. Maximum length: 65536.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the format of the content. Is Required.
  • statusID - string - StatusID references the incident status at the time of this update.
  • severityID - string - SeverityID references the incident severity at the time of this update.
  • scope - string - options: "internal" "public" "private" - Scope specifies the audience or visibility of this key update. Is Required.
  • color - string - Color is the color of the key update.

CreateKeyUpdateResponse

CreateKeyUpdateResponse is the response for the CreateKeyUpdate method.

  • keyUpdate - KeyUpdate - KeyUpdate is the newly created key update.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

CreateRoleRequest

CreateRoleRequest is the request to create a role.

  • role - Role - Role to be created to the organization

CreateRoleResponse

CreateRoleResponse is the response to create a role.

  • role - Role - Role is the newly created role.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

Cursor

Cursor describes the position in a result set. It is passed back into the same API to get the next page of results.

  • nextValue - string - NextValue is the start position of the next set of results. The implementation may change, so clients should not rely on this value. Maximum length: 4096.
  • hasMore - boolean - HasMore indicates whether there are more results or not. If HasMore is true, you can make the same request again (except using this Cursor instead) to get the next page of results.

CustomMetadataField

CustomMetadataField is a custom metadata field.

  • uuid - string - UUID is the UUID of the field.
  • name - string - Name is the name of the field. Is Required.
  • slug - string - Slug is the slug of the field. Used for searching and referencing the field as a metric. Is Required.
  • color - string - Color is the field color.
  • icon - string - Icon is the field icon.
  • description - string - Description is the description of the field.
  • type - string - options: "string" "single-select" "multi-select" "bool" "number" "date" - Type is the type of the field. Is Required.
  • required - boolean - Required is whether this field is required.
  • immutable - boolean - Immutable indicates if the field can by modified by the user.
  • domainName - string - options: "labels" "incident" - DomainName is scope for which the field is valid/used. Is Required.
  • selectoptions - array of CustomMetadataFieldSelectOption - Selectoptions is the list of select options for the field. Only used for select fields.
  • source - string - Source indicates the origin of this field (eg. incident, gops-labels, github, etc)
  • externalID - string - ExternalID, if defined, stores the ID of this field in a third-party service (eg. gops-label id)
  • archived - boolean - Archived is whether this field is archived. Archived fields are not allowed to be used in the new incidents. But the historical data is still kept.
  • version - number - Version is the field version.

CustomMetadataFieldSelectOption

CustomMetadataFieldSelectOption is a select option for a select field.

  • uuid - string - UUID is the UUID of the option.
  • value - string - Value is the value of the select option. Is Required.
  • label - string - Label is the label of the select option. Is Required.
  • color - string - Color is the color of the select option.
  • icon - string - Icon is the icon of the select option.
  • description - string - Description is the textual description of the option.
  • source - string - Source indicates the origin of this option (eg. incident, gops-labels, github, etc)
  • externalID - string - ExternalID, if defined, stores the ID of this option in a third-party service (eg. gops-label id)

CustomMetadataFieldValue

CustomMetadataFieldValue is a custom metadata field value.

  • fieldUUID - string - FieldUUID is the UUID of the field.
  • value - string - Value is the json encoded value of the field.

DeleteFieldRequest

DeleteFieldRequest is the request struct for api DeleteField method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.

DeleteFieldResponse

DeleteFieldResponse is the response from the DeleteField method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

DeleteFieldSelectOptionRequest

DeleteFieldSelectOptionRequest is the request struct for DeleteFieldSelectOption method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
  • selectOptionUUID - string - SelectOptionUUID is the UUID of the field select option to delete. Is Required.

DeleteFieldSelectOptionResponse

DeleteFieldSelectOptionResponse is the response from the DeleteFieldSelectOption method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

DeleteKeyUpdateRequest

DeleteKeyUpdateRequest is the request for the DeleteKeyUpdate method.

  • id - string - ID is the identifier of the key update to delete. Is Required.
  • incidentID - string - IncidentID is the identifier of the incident. Is Required.

DeleteKeyUpdateResponse

DeleteKeyUpdateResponse is the response for the DeleteKeyUpdate method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

DeleteRoleRequest

DeleteRoleRequest is the request to delete a role.

  • roleID - number - Role to be deleted to the organization

DeleteRoleResponse

DeleteRoleResponse is the response to delete a role.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

DeleteTaskRequest

DeleteTaskRequest is the request for the DeleteTask method.

  • incidentID - string - IncidentID is the ID of the Incident. Is Required.
  • taskID - string - TaskID is the ID of the task. Is Required.

DeleteTaskResponse

DeleteTaskResponse is the response from the DeleteTask method.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

DisableHookRequest

DisableHookRequest is the request for the DisableHook method.

  • integrationID - string - IntegrationID is the identifier of the installed integration. Is Required.
  • enabledHookID - string - EnabledHookID is the identifier of the hook to disable. Is Required.

DisableHookResponse

DisableHookResponse is the response for the DisableHook method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

EnableHookRequest

EnableHookRequest is the request for the EnableHook method.

  • integrationID - string - IntegrationID is the identifier of the installed integration. Is Required.
  • hookID - string - HookID is the identifier of the hook to enable. Is Required.
  • eventName - string - options: "incidentCreated" "incidentDeleted" "incidentUpdated" "incidentClosed" "manuallyTriggered" "incidentFilter" - EventName is the name of event to wire the hook up to. The hook will be called when this event is fired. Is Required.
  • hookConfig - HookConfig - HookConfig is the configuration values to use when enabling the hook.
  • incidentFilter - string - IncidentFilter is the filter that determines if a hook with the ‘incidentFilter’ event will be triggered.
  • sensitive - boolean - Sensitive is true if the hook run should be triggered when the incident is private. Ensures that hooks are not triggered for private incidents by default.

EnableHookResponse

EnableHookResponse is the response for the EnableHook method.

  • enabledHookID - string - EnabledHookID is the identifier of the enabled hook. This is distinct from the HookID. Is Required.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

EnabledHook

EnabledHook is a Hook that has been wired up to an event.

  • integrationID - string - IntegrationID is the identifier of the Integration that the Hook belongs to. Is Required.
  • enabledHookID - string - EnabledHookID is the unique identifier of the enabled hook. Is Required.
  • eventName - string - options: "incidentCreated" "incidentDeleted" "incidentUpdated" "incidentClosed" "manuallyTriggered" "incidentFilter" - EventName is the name of the event that this hook is wired up to.
  • hook - Hook - Hook is the enabled Hook.
  • incidentFilter - string - IncidentFilter is the filter that determines if a hook with the ‘incidentFilter’ event will be triggered.
  • sensitive - boolean - Sensitive is true if the hook run should be triggered when the incident is private. Ensures that hooks are not triggered for private incidents by default.

Field

Field represents a key/value pair, with additional metadata. Fields are used to represent dynamic data structures.

  • key - string - Key is the name of the field. Is Required.
  • type - string - options: "string" "string[grafana.apiKey:viewer]" "string[grafana.apiKey:admin]" "bool" - Type describes acceptable data for Value. Is Required.
  • description - string - Description is the description of the field.
  • value - string - Value is the value of the field when running an action. Maximum length: 1.048576e+06.
  • secret - boolean - Secret is a marker that the field contains secret data and should not be visible to users.
  • checked - boolean - Checked is true if the bool field has been checked.
  • hidden - boolean - Hidden indicates that a field should not be shown in the UI. It is not secret, just noisy, so hidden and out of the way.

FieldValue

FieldValue represents a record with a field and its value.

  • field - CustomMetadataField - Field is the field definition.
  • value - string - Value is the json encoded value of the field to record. If empty, the field value will be set unset. Is Required.

GetEnabledHooksRequest

GetEnabledHooksRequest is the request for the GetEnabledHooks method.

  • eventName - string - EventName is the name of the event that triggered the Hook to run. If provided, only Hooks that are enabled for this event will be returned.

GetEnabledHooksResponse

GetEnabledHooksResponse is the response for the GetEnabledHooks method.

  • enabledHooks - array of EnabledHook - EnabledHooks is the complete list of enabled hooks.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetFieldRequest

GetFieldRequest is the request struct for api GetField method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.

GetFieldResponse

GetFieldResponse is the response from the GetField method.

  • field - CustomMetadataField - Field is the requested field.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetFieldValuesRequest

GetFieldValuesRequest is the request struct for the GetFieldValues method.

  • targetKind - string - options: "incident" - TargetKind is the kind of the target to record the field value for. Is Required.
  • targetID - string - TargetID is the ID of the target to record the field value for. Is Required.
  • domainName - string - DomainName, if provided, will filter the results to the specified domain.

GetFieldValuesResponse

GetFieldValuesResponse is the response struct from the GetFieldValues method.

  • fieldValues - array of FieldValue - FieldValues is a list of field->value pairs.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetFieldsRequest

GetFieldsRequest is the request struct for api GetFields method.

  • domainName - string - DomainName, if provided, will filter the results to the specified domain.

GetFieldsResponse

GetFieldsResponse is the response from the GetFields method.

  • fields - array of CustomMetadataField - Fields is the list of fields.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetHomescreenVersionRequest

GetHomescreenVersionRequest is the request for the GetHomescreenVersion method.

  • No fields

GetHomescreenVersionResponse

GetHomescreenVersionResponse is the response for the GetHomescreenVersion method.

  • version - number - Version is the refresh value of the home screen. A higher value than last time indicates that the home screen should be refreshed.

GetHookRunsRequest

GetHookRunsRequest is the request for the GetHookRuns method.

  • incidentID - string - IncidentID is the identifier of the incident to get hook runs for. Is Required.

GetHookRunsResponse

GetHookRunsResponse is the response for the GetHookRuns method.

  • hookRuns - array of HookRun - HookRuns is a list of HookRuns for this Incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetIncidentMembershipRequest

GetIncidentMembershipRequest is the request for the GetIncidentMembership method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.

GetIncidentMembershipResponse

GetIncidentMembershipResponse is the response for the GetIncidentMembership method.

  • assignments - array of Assignment - IncidentMembership is the list of people involved in an incident
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetIncidentRequest

GetIncidentRequest is the request for the GetIncident method.

  • incidentID - string - IncidentID is the identifier. Is Required.

GetIncidentResponse

GetIncidentResponse is the response for the GetIncident method.

  • incident - Incident - Incident is the Incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetIncidentVersionRequest

GetIncidentVersionRequest is the request for the GetIncidentVersion method.

  • incidentID - string - IncidentID is the identifier of the Incident. A higher value than last time indicates that the dashboard should be refreshed.

GetIncidentVersionResponse

GetIncidentVersionResponse is the response for the GetIncidentVersion method.

  • version - number - Version is the refresh value of the Incident.

GetInitialKeyUpdateRequest

GetInitialKeyUpdateRequest is the request for the GetInitialKeyUpdate method.

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.

GetInitialKeyUpdateResponse

GetInitialKeyUpdateResponse is the response for the GetInitialKeyUpdate method.

  • keyUpdate - *KeyUpdate - KeyUpdate is the initial key update for the incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetKeyUpdateRequest

GetKeyUpdateRequest is the request for the GetKeyUpdate method.

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • id - string - ID is the identifier of the key update to retrieve. Is Required.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.

GetKeyUpdateResponse

GetKeyUpdateResponse is the response for the GetKeyUpdate method.

  • keyUpdate - KeyUpdate - KeyUpdate is the requested key update.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetLabelsRequest

GetLabelsRequest is the request for the GetLabels method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.

GetLabelsResponse

GetLabelsResponse is the response from the GetLabels method.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetLastKeyUpdateRequest

GetLastKeyUpdateRequest is the request for the GetLastKeyUpdate method.

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.

GetLastKeyUpdateResponse

GetLastKeyUpdateResponse is the response for the GetLastKeyUpdate method.

  • keyUpdate - *KeyUpdate - KeyUpdate is the last key update for the incident.
  • keyUpdateCount - number - Number of other key updates for this incident.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetRolesRequest

GetRolesRequest is the request to get all roles.

  • No fields

GetRolesResponse

GetRolesResponse is the response to get all roles.

  • roles - array of Role - Roles is the list of roles.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

GetUserRequest

GetUserRequest is the request for GetUser.

  • userID - string - UserID is the user ID to find the user for. All ids are in the format “provider:user-id” which allows you to refer to users from different providers. “grafana-incident:” is preferred, but all are accepted. Is Required.

GetUserResponse

GetUserResponse contains the information about a user.

  • user - User - User is the user
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

Hook

Hook describes an updatable method that may be wired up to events.

  • hookID - string - HookID is the identifier for this Hook. Is Required.
  • name - string - Name is the name of this Hook.
  • description - string - Description is a brief overview of what the hook does.

HookConfig

HookConfig holds configuration fields for a Hook.

  • fields - array of Field - Fields is a list of hook specific key/value pairs.

HookMetadata

HookMetadata contains metadata about the Run and Update of a Hook.

  • title - string - Title is a title that relates to this Hook’s run.
  • explanation - string - Explanation is a brief description about what action was taken.
  • url - string - URL is an optional URL to a place users can go for more information. Maximum length: 2048.

HookRun

HookRun describes the result of executing a Hook.

  • integrationID - string - IntegrationID is the ID of the installed Integration that the Hook belongs to. Is Required.
  • hookID - string - HookID is the ID of the Hook that was run. Is Required.
  • enabledHookID - string - EnabledHookID is the ID of the enabled hook instance. Is Required.
  • lastRun - string - LastRun is the time the hook was last run.
  • lastUpdate - string - LastUpdate is the time the hook was last updated.
  • metadata - HookMetadata - Metadata holds Hook specific key/value pairs.
  • eventName - string - options: "incidentCreated" "incidentDeleted" "incidentUpdated" "incidentClosed" "manuallyTriggered" "incidentFilter" - EventName is the name of the event that triggered the Hook to run.
  • eventKind - string - EventKind gives more detail about the type of event.
  • updateStatus - string - options: "todo" "success" "failed" - UpdateStatus is the status of the Hook update.
  • updateError - string - UpdateError is an error string to show the end-user for when UpdateStatus is “failed”.
  • status - string - options: "todo" "success" "failed" - Status is the status of the Hook run.
  • error - string - Error is an error string to show the end-user for when Status is “failed”.

Incident

Incident is a single incident.

  • incidentID - string - IncidentID is the identifier.
  • refs - array of IncidentRef - Refs represent associated IDs in third-party systems.
  • severity - string - Severity expresses how bad the Incident is.
  • labels - array of IncidentLabel - Labels is a list of strings associated with this Incident.
  • isDrill - boolean - IsDrill indicates if the Incident is a drill or not. Incidents that are drills do not show up in the dashboards, and may behave subtly differently in other ways too. For example, during drills, more help might be offered to users.
  • createdTime - string - CreatedTime is when the Incident was created. The string value format should follow RFC 3339.
  • modifiedTime - string - ModifiedTime is when the Incident was last modified. The string value format should follow RFC 3339.
  • createdByUser - UserPreview - CreatedByUser is the UserPreview that created the Incident.
  • closedTime - string - ClosedTime is when the Incident was closed. The string value format should follow RFC 3339.
  • durationSeconds - number - DurationSeconds is the number of seconds this Incident was (or is) open for.
  • status - string - options: "active" "resolved" - Status is the current status of the Incident.
  • title - string - Title is the high level description of the Incident. Maximum length: 512.
  • overviewURL - string - OverviewURL is the URL to the overview page for the Incident. Maximum length: 2048.
  • incidentMembership - IncidentMembership - Assignments describes the individuals involved in the Incident.
  • taskList - TaskList - TaskList is the list of tasks associated with the Incident.
  • summary - string - Summary is as short recap of the Incident.
  • heroImagePath - string - HeroImagePath is the path to the hero image for this Incident.
  • incidentStart - string - IncidentStart is when the Incident began. The string value format should follow RFC 3339.
  • incidentEnd - string - IncidentEnd is when the Incident ended. The string value format should follow RFC 3339.

IncidentKeyValueLabel

IncidentKeyValueLabel is a key:value label associated with an Incident.

  • key - string - Key is the label key.
  • keyUUID - string - KeyUUID is the UUID of the label key.
  • valueUUID - string - ValueUUID is the UUID of the label value.
  • value - string - Value is the value of the label.
  • description - string - Description is a short explanation of the label.
  • colorHex - string - Color is the CSS hex color of the label. Labels show up in both light and dark modes, and this should be taken into consideration when selecting a color.

IncidentLabel

IncidentLabel is a label associated with an Incident.

  • key - string - Key is the label key. If not provided, we’ll default to ’tags’.
  • label - string - Label is the text of the label.
  • description - string - Description is a short explanation of the label.
  • colorHex - string - Color is the CSS hex color of the label. Labels show up in both light and dark modes, and this should be taken into consideration when selecting a color.

IncidentMembership

IncidentMembership represents a list of people involved in an Incident.

  • assignments - array of Assignment - List of all assignments done for that incident
  • totalAssignments - number - Total of assignments including hidden roles in the incident
  • totalParticipants - number - Total of participants in the incident excluding the assigned roles

IncidentMembershipPreview

IncidentMembershipPreview is a summary of the people involved in an Incident.

  • importantAssignments - array of AssignmentPreview - ImportantAssignments is a list of all assignments done for that incident that are marked as important.
  • totalAssignments - number - Total of assignments including hidden roles in the incident
  • totalParticipants - number - Total of hidden roles (like observers) related with that incident

IncidentPreview

IncidentPreview is a minimal preview of a full Incident (omitting structured children) meant for lightweight listings or getting basic metadata.

  • incidentID - string - IncidentID is the identifier.
  • severityID - string - Severity expresses how bad the incident is.
  • severityLabel - string - SeverityLabel is the label of the severity.
  • incidentType - string - options: "internal" "private" - IncidentType indicates the kind of incident to create.
  • labels - array of IncidentLabel - Labels is a list of strings associated with this Incident.
  • isDrill - boolean - IsDrill indicates if the incident is a drill or not. Incidents that are drills do not show up in the dashboards, and may behave subtly differently in other ways too. For example, during drills, more help might be offered to users.
  • createdTime - string - CreatedTime is when the Incident was created. The string value format should follow RFC 3339.
  • modifiedTime - string - ModifiedTime is when the Incident was last modified. The string value format should follow RFC 3339.
  • closedTime - string - ClosedTime is when the Incident was closed. The string value format should follow RFC 3339.
  • createdByUser - UserPreview - CreatedByUser is the UserPreview that created the Incident.
  • title - string - Title is the high level description of the Incident. Maximum length: 512.
  • description - string - Description is a brief description of the Incident.
  • summary - string - Summary is as short recap of the incident. Maximum length: 8192.
  • heroImagePath - string - HeroImagePath is the path to the hero image for this Incident.
  • status - string - options: "active" "resolved" - Status is the current status of the Incident. Maximum length: 30.
  • slug - string - Slug is a URL friendly path segment for the Incident.
  • incidentStart - string - IncidentStart is when the Incident began. The string value format should follow RFC 3339.
  • incidentEnd - string - IncidentEnd is when the Incident ended. The string value format should follow RFC 3339.
  • fieldValues - array of CustomMetadataFieldValue - FieldValues is the list of fields associated with the Incident and their values.
  • incidentMembershipPreview - IncidentMembershipPreview - IncidentMembershipPreview is a summary of the people involved in the Incident.
  • version - number - Version is the times that the incident has been updated

IncidentPreviewsQuery

IncidentPreviewsQuery describes the query to make.

  • limit - number - Limit is the number of Incidents to return. Is Required. Maximum value: 100.
  • orderDirection - string - options: "ASC" "DESC" - OrderDirection is the direction to order the results.
  • orderField - string - options: "incidentID" "createdTime" "modifiedTime" "title" "status" "severity" "prefix" "isDrill" "incidentStart" "incidentEnd" "closedTime" - OrderField is the field on which to order the results. If empty, createdTime will be used.
  • queryString - string - QueryString is the query string to search for. If provided, the query will be filtered by the query string and the other query parameters will be ignored. Maximum length: 8192.

IncidentRef

IncidentRef represents a reference to a third-party system.

  • key - string - Key is a globally unique identifier for the third-party in reverse domain name notation.
  • ref - string - Ref is the reference string.
  • url - string - URL is the browser address of the incident in the third-party system. Can be empty. Maximum length: 2048.

IncidentsQuery

IncidentsQuery is the query for the QueryIncidentsRequest.

  • limit - number - Limit is the number of Incidents to return. Is Required. Maximum value: 100.
  • includeStatuses - array of string - IncludeStatuses is a list of statuses to include. Only Incidents with the listed statuses will be returned.
  • excludeStatuses - array of string - ExcludeStatuses is a list of statuses to exclude. All Incidents that do not match any of these values will be returned.
  • incidentLabels - array of string - IncidentLabels is a list of labels to include. An empty list will not filter by labels.
  • dateFrom - string - DateFrom if is not empty would filter by the Incidents created since that date (time.RFC3339)
  • dateTo - string - DateTo if is not empty would filter by incidents created before that date (time.RFC3339)
  • onlyDrills - boolean - OnlyDrills if is not empty filters by whether an incident is a drill or not.
  • orderDirection - string - options: "ASC" "DESC" - OrderDirection is the direction to order the results. Is Required.
  • severity - string - Severity is a list of statuses to include. Only Incidents with the listed statuses will be returned.
  • queryString - string - QueryString is the query string to search for. If provided, the query will be filtered by the query string and the other query parameters will be ignored.

IncomingWebhookResponse

IncomingWebhookResponse is the response sent back to the webhook caller when an incoming webhook has been received.

  • incident - *Incident - Incident is the newly declared incident. Only included if the incoming webhook has the include=incident URL parameter.
  • processingErrors - array of string - ProcessingErrors is a list of errors that occurred while processing the webhook. If there are items in this list it does not mean the incident wasn’t created. But you should check to make sure everything was successfully processed before shipping to production.

KeyUpdate

KeyUpdate represents a significant update or milestone in an incident’s lifecycle.

  • id - string - ID is the unique identifier for this key update. Is Required.
  • orgID - string - OrgID is the identifier of the organization this key update belongs to. Is Required.
  • incidentID - string - IncidentID is the identifier of the incident this update belongs to. Is Required.
  • title - string - Title is a short summary of the key update.
  • content - string - Content provides detailed information about the key update. Maximum length: 65536.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the format of the content. Is Required.
  • createdTime - string - CreatedTime is when this key update was created. The string value format should follow RFC 3339.
  • modifiedTime - string - ModifiedTime is when this key update was last modified. The string value format should follow RFC 3339.
  • createdBy - UserPreview - Author is the user who created this key update.
  • lastModifiedBy - UserPreview - LastEditor is the user who last modified this key update.
  • statusID - string - StatusID references the incident status at the time of this update.
  • severityID - string - SeverityID references the incident severity at the time of this update.
  • scope - string - options: "internal" "public" "private" - Scope specifies the audience or visibility of this key update. Is Required.
  • color - string - Color is the color of the key update.

KeyUpdatesQuery

KeyUpdatesQuery describes the query parameters for listing key updates.

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • limit - number - Limit is the maximum number of key updates to return. Is Required. Maximum value: 100.
  • orderDirection - string - options: "ASC" "DESC" - OrderDirection is the direction to order the results. Is Required.
  • orderField - string - options: "createdTime" "modifiedTime" "title" - OrderField is the field to order the results by. If empty, defaults to ‘createdTime’.
  • scope - string - options: "internal" "public" "private" - Scope filters key updates by their scope.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the desired format for the content field in the response.

OutgoingWebhookPayload

OutgoingWebhookPayload represents the webhook HTTP POST body and contains metadata for the webhook.

  • version - string - Version of this structure, following semantic versioning.
  • id - string - ID of event.
  • source - string - Source is a URI that identifies the context in which an event happened.
  • time - string - Time that event was generated (RFC 3339).
  • event - string - Event describes the (namespaced) event
  • incident - *Incident - Incident is the data payload, contains details about the data that was changed.

QueryActivityRequest

QueryActivityRequest is the request for the QueryActivity method.

  • query - ActivityQuery - Query describes the query to make.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.

QueryActivityResponse

QueryActivityResponse is the response from the QueryActivity method.

  • activityItems - array of ActivityItem - ActivityItems is the list of items.
  • query - ActivityQuery - Query is the query that was used to generate the response.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

QueryIncidentPreviewsRequest

QueryIncidentPreviews is the request for the QueryIncidentPreviews method.

  • query - IncidentPreviewsQuery - Query describes the query to make.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.
  • includeCustomFieldValues - boolean - IncludeCustomFieldValues if true will include custom field values in the response.
  • includeMembershipPreview - boolean - IncludeMembershipPreview if true will include membership previews in the response.

QueryIncidentPreviewsResponse

QueryIncidentPreviewsResponse is the response for the QueryIncidentPreviews method.

  • incidentPreviews - array of IncidentPreview - IncidentPreviews is a list of Incident Previews.
  • query - IncidentPreviewsQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

QueryIncidentsRequest

QueryIncidentsRequest is the request for the QueryIncidents method.

  • query - IncidentsQuery - Query describes the query to make.
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.

QueryIncidentsResponse

QueryIncidentsResponse is the response for the QueryIncidents method.

  • incidents - array of Incident - Incidents is a list of Incidents.
  • query - IncidentsQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

QueryKeyUpdatesRequest

QueryKeyUpdatesRequest is the request for the QueryKeyUpdates method.

  • query - KeyUpdatesQuery - Query describes the query parameters.
  • cursor - Cursor - Cursor is used for pagination. Empty for the first page. For subsequent pages, use previously returned Cursor values.

QueryKeyUpdatesResponse

QueryKeyUpdatesResponse is the response for the QueryKeyUpdates method.

  • keyUpdates - array of KeyUpdate - KeyUpdates is the list of key updates matching the query.
  • query - KeyUpdatesQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

QueryUsersRequest

QueryUsersRequest is the request for getting a list of users.

  • query - UsersQuery - Query describes the query to make
  • cursor - Cursor - Cursor is used to page through results. Empty for the first page. For subsequent pages, use previously returned Cursor values.

QueryUsersResponse

QueryUsersResponse is the response from QueryUsers.

  • users - array of User - Users is a list of Users.
  • query - UsersQuery - Query is the query that was used to generate this response.
  • cursor - Cursor - Cursor should be passed back to get the next page of results.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

RemoveActivityRequest

RemoveActivityRequest is the request for the RemoveActivity method.

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.

RemoveActivityResponse

RemoveActivityResponse is the response from the RemoveActivity method.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

RemoveLabelRequest

RemoveLabelRequest is the request for the RemoveLabel method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • label - string - Label is the label to remove from the Incident.

RemoveLabelResponse

RemoveLabelResponse is the response for the RemoveLabel method.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

Role

Role represents a role that will be used to assign people in the incident.

  • roleID - number - RoleID is the unique ID of this role.
  • orgID - string - OrgID is the unique ID of the organization this role belongs to.
  • name - string - Name is the name of the role.
  • description - string - Description is the description of the role.
  • important - boolean - Important is whether this role is important.
  • mandatory - boolean - Mandatory is whether this role is mandatory.
  • archived - boolean - Archived is whether this role is archived. Archived roles are not allowed to be assigned to people in the new incidents. But the historical data is still kept.
  • createdAt - string - CreatedAt is the time this role was created at.
  • updatedAt - string - UpdatedAt is the time this role was updated at.

Task

Task is an individual task that somebody will do to resolve an Incident.

  • taskID - string - TaskID is the ID of the task. Is Required.
  • immutable - boolean - Immutable is true if the task cannot be changed. Used for tasks created and maintained by the system (like role assignment tasks). Is Required.
  • createdTime - string - CreatedTime is the time the task was created.
  • modifiedTime - string - ModifiedTime is the time
  • text - string - Text is the string that describes the Task. Maximum length: 65536.
  • status - string - options: "todo" "progress" "done" - Status os the status of this task.
  • authorUser - *UserPreview - AuthorUser is the person who created this task.
  • assignedUser - *UserPreview - AssignedUser is the person this task is assigned to.

TaskList

TaskList is a list of tasks.

  • tasks - array of Task - Tasks is a list of tasks.
  • todoCount - number - TodoCount is the number of items in the list that are not yet done.
  • doneCount - number - DoneCount is the number of items in the list that are done.

UnarchiveFieldRequest

UnarchiveFieldRequest is the request struct for api UnarchiveField method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.

UnarchiveFieldResponse

UnarchiveFieldResponse is the response from the UnarchiveField method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UnarchiveRoleRequest

UnarchiveRoleRequest is the request to unarchive a role.

  • roleID - number - Role to be unarchived to the organization

UnarchiveRoleResponse

UnarchiveRoleResponse is the response to unarchive a role.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UnassignLabelByUUIDRequest

UnassignLabelByUUIDRequest is the request for the UnassignLabelByUUID method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • keyUUID - string - KeyUUID is the label key uuid. Is Required.
  • valueUUID - string - ValueUUID is the UUID of the label value. Is Required.

UnassignLabelByUUIDResponse

UnassignLabelByUUIDResponse is the response from the UnassignLabelByUUID method.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UnassignLabelRequest

UnassignLabelRequest is the request for the UnassignLabel method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • key - string - Key is the label key. Is Required.
  • value - string - Value is the value of the label. Is Required.

UnassignLabelResponse

UnassignLabelResponse is the response from the UnassignLabel method.

  • labels - array of IncidentKeyValueLabel - Labels is a list of labels
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UnassignRoleRequest

UnassignRoleRequest is the request for the UnassignRole method.

  • incidentID - string - IncidentID is the identifier. Is Required.
  • userID - string - UserID is the identifier of the person to assign the role to. Is Required.
  • role - string - options: "commander" "investigator" "observer" - Role is the role of this person. Is Required.

UnassignRoleResponse

UnassignRoleResponse is the response for the UnassignRole method.

  • incident - Incident - Incident is the Incident that was just updated.
  • didChange - boolean - DidChange indicates if the role was changed or not. If the role was not assigned, this will be false.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateActivityBodyRequest

UpdateActivityBodyRequest is the request for the UpdateActivityBody method.

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
  • body - string - Body is the new body to use for the given activity item Is Required. Maximum length: 65536.

UpdateActivityBodyResponse

UpdateActivityBodyResponse is the response from the UpdateActivityBody method.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateActivityEventTimeRequest

UpdateActivityEventTimeRequest is the request for the UpdateActivityEventTime method.

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
  • eventTime - string - EventTime is the time when the event occurred. If empty, the created time of the activity item is used. The string value format should follow RFC 3339.

UpdateActivityEventTimeResponse

UpdateActivityEventTimeResponse is the response from the UpdateActivityEventTime method.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateActivityRelevanceRequest

UpdateActivityRelevanceRequest is the request for the UpdateActivityRelevance method.

  • incidentID - string - IncidentID is the identifier. Is Required.
  • activityItemID - string - ActivityItemID is the unique identifier of the ActivityItem. Is Required.
  • relevance - string - options: "automatic" "archive" "low" "normal" "high" - Relevance is the preferred relevance of the activity item. if set to ‘automatic’ (the default), the relevance will be guessed automatically. Is Required.

UpdateActivityRelevanceResponse

UpdateActivityRelevanceResponse is the response from the UpdateActivityRelevance method.

  • activityItem - ActivityItem - ActivityItem is the updated ActivityItem.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateFieldRequest

UpdateFieldRequest is the request struct for api UpdateField method.

  • fieldUUID - string - FieldUUID is the UUID of the field.
  • name - string - Name is the name of the field.
  • slug - string - Slug is the slug of the field. Used for searching and referencing the field as a metric.
  • color - string - Color is the field color.
  • icon - string - Icon is the field icon.
  • description - string - Description is the description of the field.
  • required - boolean - Required is whether this field is required.
  • domainName - string - DomainName is single-select for which a field is valid/used.
  • immutable - boolean - Immutable indicates if the field can by modified by the user.
  • selectoptions - array of CustomMetadataFieldSelectOption - Selectoptions is the list of select options for the field. Only used for select fields.
  • version - number - Version is the field version. Is Required.

UpdateFieldResponse

UpdateFieldResponse is the response from the UpdateField method.

  • field - CustomMetadataField - Field is the field that was updated.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateFieldSelectOptionRequest

UpdateFieldSelectOptionRequest is the request struct for UpdateFieldSelectOption method.

  • fieldUUID - string - FieldUUID is the UUID of the field. Is Required.
  • selectOptionUUID - string - SelectOptionUUID is the UUID of the field select option to delete. Is Required.
  • value - string - Value is the value of the select option.
  • label - string - Label is the label of the select option.
  • color - string - Color is the color of the select option.
  • icon - string - Icon is the icon of the select option.
  • description - string - Description is the textual description of the option.

UpdateFieldSelectOptionResponse

UpdateFieldSelectOptionResponse is the response from the UpdateFieldSelectOption method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateIncidentEventTimeRequest

UpdateIncidentEventTimeRequest is the request for the UpdateIncidentEventTime method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • eventTime - string - EventTime is the new time for the start or end of the incident. The string value format should follow RFC 3339. Is Required.
  • activityItemKind - string - options: "incidentEnd" "incidentStart" - ActivityItemKind is either the incidentEnd or incidentStart time. deprecated. use EventName instead, ActivityItemKind will be removed soon. Is Required.
  • eventName - string - options: "incidentEnd" "incidentStart" - EventName is either the incidentEnd or incidentStart time. Is Required.

UpdateIncidentEventTimeResponse

UpdateIncidentEventTimeResponse is the response for the UpdateIncidentEventTime method.

  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateIncidentIsDrillRequest

UpdateIncidentIsDrillRequest is the request for the UpdateIncidentIsDrill method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • isDrill - boolean - IsDrill indicates whether the Incident is a drill or not.

UpdateIncidentIsDrillResponse

UpdateIncidentIsDrillResponse is the response for the UpdateIncidentIsDrill method.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateKeyUpdateRequest

UpdateKeyUpdateRequest is the request for the UpdateKeyUpdate method.

  • incidentID - string - IncidentID is the identifier of the incident. Is Required.
  • id - string - ID is the identifier of the key update to modify. Is Required.
  • title - string - Title is the new title for the key update.
  • content - string - Content is the new content for the key update. Is Required. Maximum length: 65536.
  • contentType - string - options: "text/plain" "application/x-lexical-editor" "text/markdown+slack" "text/markdown+msteams" - ContentType specifies the format of the content. Is Required.
  • statusID - string - StatusID references the incident status at the time of this update.
  • severityID - string - SeverityID references the incident severity at the time of this update.
  • scope - string - options: "internal" "public" "private" - Scope specifies the audience or visibility of this key update.
  • color - string - Color is the color of the key update.

UpdateKeyUpdateResponse

UpdateKeyUpdateResponse is the response for the UpdateKeyUpdate method.

  • keyUpdate - KeyUpdate - KeyUpdate is the modified key update.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateRoleRequest

UpdateRoleRequest is the request to update a role.

  • role - Role - Role to be updated to the organization

UpdateRoleResponse

UpdateRoleResponse is the response to update a role.

  • role - Role - Role is the newly updated role.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateSeverityRequest

UpdateSeverityRequest is the request for the UpdateSeverity method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • severity - string - Severity expresses how bad the Incident is. Is Required.

UpdateSeverityResponse

UpdateSeverityResponse is the response for the UpdateSeverity method.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateStatusRequest

UpdateStatusRequest is the request for the UpdateStatus method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • status - string - options: "active" "resolved" - Status is the new status of the Incident. Is Required.

UpdateStatusResponse

UpdateStatusResponse is the response for the UpdateStatus method.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateTaskStatusRequest

UpdateTaskStatusRequest is the request for the UpdateTaskStatus method.

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • taskID - string - TaskID is the ID of the Task to update. Is Required.
  • status - string - options: "todo" "progress" "done" - Status is the new status of this task. Is Required.

UpdateTaskStatusResponse

UpdateTaskStatusResponse is the response from the UpdateTaskStatus method.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateTaskTextRequest

UpdateTaskTextRequest is the request for the UpdateTaskText method.

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • taskID - string - TaskID is the ID of the task. Is Required.
  • text - string - Text is the string that describes the Task. Maximum length: 65536.

UpdateTaskTextResponse

UpdateTaskTextResponse is the response from the UpdateTaskText method.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateTaskUserRequest

UpdateTaskUserRequest is the request for the UpdateTaskUser method.

  • incidentID - string - IncidentID is the ID of the Incident to add the Task to. Is Required.
  • taskID - string - TaskID is the ID of the Task to update. Is Required.
  • userID - string - UserID is the ID of the User to assign to the Task.

UpdateTaskUserResponse

UpdateTaskUserResponse is the response from the UpdateTaskUser method.

  • incidentID - string - IncidentID is the ID of the incident these tasks relate to. Is Required.
  • task - Task - Task is the newly added Task. It will also appear in Tasks.
  • taskList - TaskList - TaskList is the tasks list.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

UpdateTitleRequest

UpdateTitleRequest is the request for the UpdateTitle method.

  • incidentID - string - IncidentID is the identifier of the Incident. Is Required.
  • title - string - Title is the new title of the Incident. Is Required.

UpdateTitleResponse

UpdateTitleResponse is the response for the UpdateTitle method.

  • incident - Incident - Incident is the Incident that was just modified.
  • error - string - Error is string explaining what went wrong. Empty if everything was fine.

User

User contains the details of a person.

  • userID - string - UserID is the identifier. It is in the format “provider:user-id” which allows you to refer to users from different providers. Sometimes, the same user is represented by multiple identifiers. You may always use this field whenever you need to refer to a user, the server will resolve them for you. “grafana-incident:{id}” is preferred.
  • internalUserID - string - InternalUserID is the internal user ID as stored in the database.
  • email - string - Email is the user’s email address.
  • modifiedTime - string - ModifiedTime is when this user was last modified. The string value format should follow RFC 3339.
  • name - string - Name is the user full name.
  • photoURL - string - PhotoURL is the user’s photo URL. Maximum length: 2048.
  • grafanaUserID - string - GrafanaUserID is the Grafana user ID.
  • grafanaLogin - string - GrafanaLogin is the Grafana login.
  • slackUserID - string - SlackUserID is the Slack user ID.
  • slackTeamID - string - SlackTeamID is the Slack organization ID.
  • msTeamsUserID - string - MsTeamsUserID is the MS Teams organization ID.

UserPreview

UserPreview is a user involved in an Incident.

  • userID - string - UserID is the identifier for the user.
  • name - string - Name is a human readable string that represents the user.
  • photoURL - string - PhotoURL is the URL to the profile picture of the user. Maximum length: 2048.

UsersQuery

UsersQuery is the request for getting a list of users.

  • limit - number - Limit is the max number of users to return. Is Required. Maximum value: 100.

This documentation was dynamically generated, please report any issues.