GraphQLを使用したマジックファイアウォールサンプルのクエリ
この例では、GraphQL Analytics APIを使用して、指定された期間のマジックファイアウォールサンプルをクエリします。
以下のAPI呼び出しは、1時間の期間にわたるマジックファイアウォールサンプルを要求し、要求されたフィールドを出力します。<CLOUDFLARE_ACCOUNT_ID>、<EMAIL>、および<API_KEY>をあなたのゾーンタグとAPI資格情報に置き換え、datetime_geqおよびdatetime_leqの値を好みに応じて調整してください。
echo '{ "query": "query MFWActivity { viewer { accounts(filter: { accountTag: $accountTag }) { magicFirewallSamplesAdaptiveGroups( filter: $filter limit: 10 orderBy: [datetimeFiveMinute_DESC] ) { sum { bits packets } dimensions { datetimeFiveMinute ruleId } } } } }", "variables": { "accountTag": "<CLOUDFLARE_ACCOUNT_ID>", "filter": { "datetime_geq": "2022-07-24T11:00:00Z", "datetime_leq": "2022-07-24T11:10:00Z" } }}' | tr -d '\n' | curl --silent \https://api.cloudflare.com/client/v4/graphql \--header "Authorization: Bearer <API_TOKEN>" \--header "Accept: application/json" \--header "Content-Type: application/json" \--data @-返された値は、特定のルールに対して5分間の間に受信したパケットとビットの合計数を表します。結果はJSON形式(要求された通り)で返されるため、出力をjqにパイプすることで、以下の例のように読みやすくなります。
... | curl --silent \https://api.cloudflare.com/client/v4/graphql \--header "Authorization: Bearer <API_TOKEN>" \--header "Accept: application/json" \--header "Content-Type: application/json" \--data @- | jq .
#=> {#=> "data": {#=> "viewer": {#=> "accounts": [#=> {#=> "magicFirewallSamplesAdaptiveGroups": [#=> {#=> sum: { bits: 327680, packets: 16384 },#=> dimensions: {#=> datetimeFiveMinute: '2021-05-12T22:00-00:00',#=> ruleId: 'bdfa8f8f0ae142b4a70ef15f6160e532'#=> }#=> },#=> {#=> sum: { bits: 360448, packets: 8192 },#=> dimensions: {#=> datetimeFiveMinute: '2021-05-12T22:05-00:00',#=> ruleId: 'bdfa8f8f0ae142b4a70ef15f6160e532'#=> }#=> },#=> {#=> sum: { bits: 327680, packets: 8192 },#=> dimensions: {#=> datetimeFiveMinute: '2021-05-12T22:05-00:00',#=> ruleId: 'bdfa8f8f0ae142b4a70ef15f6160e532'#=> }#=> },#=> {#=> sum: { bits: 360448, packets: 8192 },#=> dimensions: {#=> datetimeFiveMinute: '2021-05-12T22:20-00:00',#=> ruleId: 'bdfa8f8f0ae142b4a70ef15f6160e532'#=> }#=> },#=> {#=> sum: { bits: 327680, packets: 8192 },#=> dimensions: {#=> datetimeFiveMinute: '2021-05-12T22:20-00:00',#=> ruleId: 'bdfa8f8f0ae142b4a70ef15f6160e532'#=> }#=> }#=> ]#=> }#=> ]#=> }#=> },#=> "errors": null#=> }