アラートルールの追加
最終更新日: 29 年 2022 月 XNUMX 日概要
LogicMonitorのRESTAPIを使用して、プログラムでアラートルールを追加できます。 すべてのAPI呼び出しと同様に、 認証が必要です.
詳細依頼フォーム
HTTPメソッド: POST
URI: / settings / alert / rules
リクエストパラメータ: アラートルールの次のプロパティをPOSTできます。
プロパティ | 説明 | 必須? | 例 | |
名 | アラートルールの名前 | ○ | 文字列 | 「名前」:「prodDBErrors」 |
優先順位 | アラートルールに関連付けられた優先度 | ○ | 整数 | 「優先度」:100 |
レベルスト | アラートの重大度レベルは、アラートルールが一致するように構成されています。 可能な値はすべて| 警告| エラー| クリティカル | いいえ。デフォルトは「すべて」です。 | 文字列 | 「levelStr」:「すべて」 |
デバイス | アラートルールが一致するように構成されているデバイス名とサービス名 | いいえ。すべてのデバイスのデフォルトは*です。 | JSON配列 | 「デバイス」:[「prod *」] |
デバイスグループ | アラートルールが一致するように構成されているデバイスグループとサービスグループ | いいえ。すべてのグループのデフォルトは*です。 | JSON配列 | “ deviceGroups”:[“ Production *”] |
情報源 | アラートルールが一致するように構成されているデータソース | ○ | 文字列 | 「データソース」:「* SQL *」 |
アラートルールが一致するように構成されているインスタンス | ○ | 文字列 | 「インスタンス」:「*」 | |
データポイント | アラートルールが一致するように構成されているデータポイント | ○ | 文字列 | 「データポイント」:「*」 |
エスカレーション間隔 | アラートルールに関連付けられたエスカレーション間隔(分単位) | ○ | 整数 | 「escalationInterval」:15 |
エスカレートしているChainId | アラートルールに関連付けられたエスカレーションチェーンのID | ○ | 整数 | 「escalatingChainId」:12 |
抑制アラートクリア | アラートクリア通知をアラートルールに送信する必要があるかどうか | いいえ。デフォルトはfalseです。 | ブーリアン | 「suppressAlertClear」:true |
抑制アラート | 確認応答とSDTのステータス通知をアラートルールに送信する必要があるかどうか | いいえ。デフォルトはfalseです。 | ブーリアン | 「suppressAlertAckSdt」:false |
例
次の例では、すべてのグループ、すべてのデバイスにわたるSQLデータソース(名前にSQLを含むすべてのデータソース)のすべてのアラートに適用される、優先度1000のルール「DBAlerts」を追加します。
#!/bin/env python
import requests
import json
import hashlib
import base64
import time
import hmac
#Account Info
AccessId ='API-ACCESS-ID'
AccessKey ='API-ACCESS-KEY'
Company = 'api'
##Request Info
httpVerb ='POST'
resourcePath = '/setting/alert/rules'
queryParams =''
data = '{"name":"DBAlerts","priority":1000,"datasource":"*MYSQL*","instance":"*","datapoint":"*","escalationInterval":15,"escalatingChainId":1}'
#Construct URL
url = 'https://'+ Company +'.logicmonitor.com/santaba/rest' + resourcePath +queryParams
#Get current time in milliseconds
epoch = str(int(time.time() * 1000))
#Concatenate Request details
requestVars = httpVerb + epoch + data + resourcePath
# Construct signature
hmac1 = hmac.new(AccessKey.encode(),msg=requestVars.encode(),digestmod=hashlib.sha256).hexdigest()
signature = base64.b64encode(hmac1.encode())
# Construct headers
auth = 'LMv1 ' + AccessId + ':' + signature.decode() + ':' + epoch
headers = {'Content-Type':'application/json','Authorization':auth}
# Make request
response = requests.post(url, data=data, headers=headers)
# Print status and body of response
print('Response Status:',response.status_code)
print('Response Body:',response.content)