{
  "annotations": {
    "list": [
      {
        "builtIn": 1,
        "datasource": {
          "type": "grafana",
          "uid": "-- Grafana --"
        },
        "enable": true,
        "hide": true,
        "iconColor": "rgba(0, 211, 255, 1)",
        "name": "Annotations & Alerts",
        "type": "dashboard"
      }
    ]
  },
  "editable": true,
  "fiscalYearStartMonth": 0,
  "graphTooltip": 0,
  "links": [],
  "panels": [
    {
      "fieldConfig": {
        "defaults": {},
        "overrides": []
      },
      "gridPos": {
        "h": 3,
        "w": 24,
        "x": 0,
        "y": 0
      },
      "id": 1,
      "options": {
        "code": {
          "language": "plaintext",
          "showLineNumbers": false,
          "showMiniMap": false
        },
        "content": "# История подписки\n\n**Отчёт:** $sub_name  \n**SubscriptionID:** `$sub_id`\n\nНиже — все записи истории доставки с ошибками (Status > 0), новые сверху. Колонка «Сообщения об ошибках» содержит извлечённый из JSON текст ошибок (Details → Errors[].Message), кириллица декодирована, несколько сообщений склеены в одну ячейку.",
        "mode": "markdown"
      },
      "pluginVersion": "12.4.2",
      "title": "",
      "transparent": true,
      "type": "text"
    },
    {
      "datasource": {
        "type": "mssql",
        "uid": "${DS_MSSQL}"
      },
      "description": "История доставки подписки. Поля: ID — SubscriptionHistoryID (автоинкремент, сортировка по убыванию); Начало/Окончание — StartTime/EndTime записи; Статус — код результата (>0 = ошибка); Сообщение — поле Message из истории; Сообщения об ошибках — извлечённые из JSON Details сообщения (Errors[].Message), склеенные через перенос строки. Фильтр по SubscriptionID из URL.",
      "fieldConfig": {
        "defaults": {
          "custom": {
            "align": "auto",
            "cellOptions": {
              "type": "auto"
            },
            "filterable": true,
            "footer": {
              "reducers": []
            },
            "inspect": false,
            "wrapText": true
          },
          "mappings": [],
          "thresholds": {
            "mode": "absolute",
            "steps": [
              {
                "color": "green",
                "value": 0
              },
              {
                "color": "red",
                "value": 80
              }
            ]
          }
        },
        "overrides": [
          {
            "matcher": {
              "id": "byName",
              "options": "Статус"
            },
            "properties": [
              {
                "id": "custom.cellOptions",
                "value": {
                  "type": "color-background"
                }
              },
              {
                "id": "thresholds",
                "value": {
                  "mode": "absolute",
                  "steps": [
                    {
                      "color": "green",
                      "value": 0
                    },
                    {
                      "color": "red",
                      "value": 1
                    }
                  ]
                }
              },
              {
                "id": "custom.width",
                "value": 80
              }
            ]
          },
          {
            "matcher": {
              "id": "byName",
              "options": "ID"
            },
            "properties": [
              {
                "id": "custom.width",
                "value": 90
              }
            ]
          },
          {
            "matcher": {
              "id": "byName",
              "options": "Сообщения об ошибках"
            },
            "properties": [
              {
                "id": "custom.width",
                "value": 700
              }
            ]
          }
        ]
      },
      "gridPos": {
        "h": 26,
        "w": 24,
        "x": 0,
        "y": 3
      },
      "id": 2,
      "options": {
        "cellHeight": "md",
        "showHeader": true
      },
      "pluginVersion": "12.4.2",
      "targets": [
        {
          "datasource": {
            "type": "mssql",
            "uid": "${DS_MSSQL}"
          },
          "format": "table",
          "rawQuery": true,
          "rawSql": "SELECT\n    sh.SubscriptionHistoryID AS [ID],\n    sh.StartTime,\n    sh.EndTime,\n    sh.Status,\n    sh.Message,\n    agg.ErrorMessages\nFROM ReportServer.dbo.SubscriptionHistory sh\nCROSS APPLY (\n    SELECT CASE\n             WHEN ISJSON(sh.Details) = 1 THEN sh.Details\n             ELSE REPLACE(REPLACE(REPLACE(sh.Details, CHAR(13), ' '), CHAR(10), ' '), CHAR(9), ' ')\n           END AS doc\n) cleaned\nOUTER APPLY (\n    SELECT STRING_AGG(JSON_VALUE(e.value, '$.Message'), CHAR(13)+CHAR(10)) AS ErrorMessages\n    FROM OPENJSON(cleaned.doc, '$.Errors') e\n    WHERE ISJSON(cleaned.doc) = 1\n) agg\nWHERE sh.SubscriptionID = '$sub_id'\n  AND sh.Status > 0\nORDER BY sh.SubscriptionHistoryID DESC;",
          "refId": "A"
        }
      ],
      "title": "Записи истории (ошибки)",
      "transformations": [
        {
          "id": "organize",
          "options": {
            "excludeByName": {},
            "indexByName": {},
            "renameByName": {
              "EndTime": "Окончание",
              "ErrorMessages": "Сообщения об ошибках",
              "Message": "Сообщение",
              "StartTime": "Начало",
              "Status": "Статус"
            }
          }
        }
      ],
      "type": "table"
    }
  ],
  "preload": false,
  "refresh": "",
  "schemaVersion": 42,
  "tags": [
    "pbirs",
    "ssrs",
    "subscription-history"
  ],
  "templating": {
    "list": [
      {
        "current": {},
        "includeAll": false,
        "label": "База ReportServer",
        "name": "DS_MSSQL",
        "options": [],
        "query": "mssql",
        "refresh": 1,
        "regex": "",
        "type": "datasource"
      },
      {
        "current": {
          "text": "00000000-0000-0000-0000-000000000000",
          "value": "00000000-0000-0000-0000-000000000000"
        },
        "hide": 2,
        "label": "SubscriptionID",
        "name": "sub_id",
        "options": [
          {
            "selected": true,
            "text": "00000000-0000-0000-0000-000000000000",
            "value": "00000000-0000-0000-0000-000000000000"
          }
        ],
        "query": "00000000-0000-0000-0000-000000000000",
        "type": "textbox"
      },
      {
        "current": {
          "text": "/Папка/Имя отчёта",
          "value": "/Папка/Имя отчёта"
        },
        "hide": 2,
        "label": "Subscription name",
        "name": "sub_name",
        "options": [
          {
            "selected": true,
            "text": "/Папка/Имя отчёта",
            "value": "/Папка/Имя отчёта"
          }
        ],
        "query": "/Папка/Имя отчёта",
        "type": "textbox"
      }
    ]
  },
  "time": {
    "from": "now-3h",
    "to": "now"
  },
  "timepicker": {},
  "timezone": "browser",
  "title": "История подписки",
  "uid": "pbirs-sub-history",
  "version": 4,
  "weekStart": "",
  "__inputs": [
    {
      "name": "DS_MSSQL",
      "label": "База ReportServer (MSSQL)",
      "description": "Datasource MSSQL, указывающий на базу ReportServer",
      "type": "datasource",
      "pluginId": "mssql",
      "pluginName": "Microsoft SQL Server"
    }
  ],
  "id": null
}