21
16

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Microsoft Graph を使ってみよう : 基本的な操作

Last updated at Posted at 2018-05-22

基本の 7 操作

Microsoft Graph は多くのリソースにおいて以下の操作をサポートします。

コレクションの取得

HTTP Get 要求でリソースに対して一覧を取得します。

例)
/users: ユーザーのコレクション
/groups: グループのコレクション

SDK を使う場合
コレクションの取得はリソースに対して Request().GetAsync() を実行。

C#
await graphClient.Users.Request().GetAsync();

単一レコードの取得

リソースに対してレコード ID を指定することで単一レコードを取得します。

/users/{id}: 特定のユーザー
/me: サインインしているユーザーの /users/{id} ショートカット

SDK を使う場合
単一レコードは ID を指定して実行。

C#
await graphClient.Users["レコードのID"].Request().GetAsync();
await graphClient.Me.Request().GetAsync();

レコードの作成

コレクションに対する HTTP Post 要求でレコードが作成できます。

SDK を使う場合
リソースに対して Request().AddAsync() メソッドに作成するオブジェクトを渡して実行。

C#
await graphClient.Users.Request().AddAsync(user);

レコードの更新

単一レコード URL に対する HTTP Patch 要求で更新します。

SDK を使う場合
単一レコードの指定に対して更新するオブジェクトを渡して実行。

C#
await graphClient.Users["レコードのID"].Request().UpdateAsync(user);

レコードの削除

単一レコード URL に対する HTTP Delete 要求で削除します。

SDK を使う場合
単一レコードの指定に対して、削除を実行。

C#
await graphClient.Users["レコードのID"].Request().DeleteAsync();

関数の実行

Microsoft Graph では関数のアドレスに HTTP Post 要求を送信することで、メールを送信するなど操作を実行することが出来ます。

例)
/me/messages/{id}/send: メール送信
/me/messages/{id}/move: メールの移動

SDK を使う場合
操作を行う単位に対してメソッドを実行。

C#
graphClient.Me.Messages["id"].Send();
graphClient.Me.Messages["id"].Move("another folder");

バッチ処理

$batch URL に HTTP Post 要求を送信することで複数の要求をバッチ処理できます。

POST https://graph.microsoft.com/v1.0/$batch

Body
{
  "requests": [
    {
      "id": "1",
      "method": "GET",
      "url": "/me/drive/root:/{file}:/content"
    },
    {
      "id": "2",
      "method": "GET",
      "url": "/me/planner/tasks"
    },
    {
      "id": "3",
      "method": "GET",
      "url": "/groups/{id}/events"
    },
    {
      "id": "4",
      "url": "/me",
      "method": "PATCH",
      "body": {
        "city" : "Redmond"
      },
      "headers": {
        "Content-Type": "application/json"
      }
    }
  ]
}

SDK を使う場合
現時点ではまた C# 用のライブラリには実装されていないようです。

制限

  • ネストされたバッチ要求はサポートされません
  • すべての要求は同期で実行されます
  • トランザクションはサポートされません
  • 最大 20 要求を処理できます

基本の 7 クエリ

Microsoft Graph では多くのリソースにおいて、以下の OData クエリをサポートします。

SELECT クエリ

OData の Select クエリをサポートしているため、以下のようなクエリをかけます。

/users?$select=displayName,jobTitle,userPrincipalName
Capture.PNG

SDK を使う場合

C#
await graphClient.Users.Request().Select("displayName,jobTitle").GetAsync();

FILTER クエリ

レコードのフィルタリングを行うことが出来ます。

/users?$filter=startswith(mail, 'admin')
Capture.PNG

SDK を使う場合

C#
await graphClient.Users.Request().Filter("startswith(mail,'admin')").GetAsync()

ORDERBY クエリ

レコードの慣れべ替えを行います。

/users?$orderby=displayName
Capture.PNG

SDK を使う場合

C#
await graphClient.Users.Request().OrderBy("displayName").GetAsync()

TOP クエリ

上位 x 件のレコードを取得する場合は、TOP クエリが利用できます。以下の場合、上位 1 件を取得していますが、結果はコレクションとして返ります。

/users?$top=1
Capture.PNG

SDK を使う場合

C#
await graphClient.Users.Request().Top(1).GetAsync();

SKIP クエリ

手動ページングをしたい場合などに、レコードを x 件スキップすることが出来ます。リソースによってはサポートされません。TOP クエリと一緒に使われることが多いです。

/me/mailFolders?$top=1&$skip=1
Capture.PNG

SDK を使う場合

C#
await graphClient.Me.MailFolders.Request().Top(1).Skip(1).GetAsync();

EXPAND クエリ

関連リソースをメインのリソースと同時に展開して取得します。

/me/drive/root?$expand=children
Capture.PNG

SDK を使う場合

C#
await graphClient.Me.Drive.Root.Request().Expand("children").GetAsync();

SEARCH クエリ

FILTER クエリと似ていますが、検索キーワードで検索が行えます。現在は以下のリソースで実行可能です。

  • 人物コレクション
  • メールコレクション

メールについては Outlook の検索でも利用できる、キーワード クエリ言語 (KQL) 構文で検索を実行できます。

me/messages?$search="from:manager1@graphdemo01.onmicrosoft.com"

SDK を使う場合

Search メソッドが存在するはずですが、現在の SDK に見当たらなったため、QueryOption で実行。検索文字列をダブルクォーテーションで囲む場合、エスケープしてください。

C#
var users = await graphClient.Me.Messages.Request(
    new List<Option>() {
        new QueryOption("$search", "\"from:manager1@graphdemo01.onmicrosoft.com\"")
    }).GetAsync();

COUNT クエリ

レコードの総数を確認したい場合、COUNT クエリを使います。リソースによってはサポートされません。

/me/mailFolders?$count=true
Capture.PNG

SDK を使う場合

C#
await graphClient.Me.MailFolders.Request(new List<QueryOption>()
    { new QueryOption("$count", "true") }).GetAsync();

Tips

Microsoft Graph を使う上でいくつか Tips を紹介します。

リレーションシップを使ったナビゲーション

Microsoft Graph は関連を辿ったレコードの取得が可能です。例えば自分のマネージャーは以下のパスで取得できます。

/me/manager
Capture.PNG

SDK を使う場合

C#
await graphClient.Me.Manager.Request().GetAsync();

ID で特定レコードを取得

コレクションで返る場合、ID を指定することで単独レコードとして取得が可能です。ID はリソースによって形式が異なります。

/users/: id で指定したユーザーのレコードのみが返る
Capture.PNG

SDK を使う場合

C#
var user = await graphClient.Users["6746d79d-8c77-4eec-a61f-cce6beb162f7"].Request().GetAsync();

ページング

レコードが一度のクエリで取得しきれない場合、ページング情報が応答に含まれます。すべてのレコードを取得する場合は、継続してページングリンクにアクセスして情報を取得します。@odata.nextLink にページング用のアドレスが含まれます。

メタデータ

Microsoft Graph ではリソースのクエリだけでなく、メタデータを取得することも出来ます。

Microsoft Graph API v1.0 メタデータ
https://graph.microsoft.com/v1.0/$metadata

Microsoft Graph API beta メタデータ
https://graph.microsoft.com/beta/$metadata

Open API 定義

上記メタデータ以外に、Open API (旧Swagger) をサポートします。現在はまだ GitHub で公開されているだけですが、将来的にはサービスに組み込まれる予定です。

Microsoft Graph OpenAPI v3.0.1 description (preview)

要求の同時実行制限

Microsoft Graph の同時呼び出しが多すぎた場合、リクエストがスロットリングで調整される場合があります。その際は HTTP ステータスコード 429 (Too many requests) が返るため、あらかじめ数秒待機後にリトライする処理を入れるようにしてください。その他のエラーについては Microsoft Graph のエラー応答とリソースの種類 を参照。

データの差分取得

いくつかのリソースでは前回データ取得時からの変更だけが取得できる機能があります。次回詳細を見ていきます。

変更通知

いくつかのリソースでは、Webhook を使った変更通知を受け取れます。こちらも今後の記事で詳細を紹介します。

まとめ

まず基本的な操作をおさえることで、より効率の良い開発が行えるようになります。是非導入してください。

目次へ戻る

参照

Microsoft Graph API を使用する
クエリ パラメーターを使用して応答をカスタマイズする
Microsoft Graph スロットリングについて
Microsoft Graph に関する既知の問題
Microsoft Graph のエラー応答とリソースの種類
Microsoft Graph OpenAPI v3.0.1 description (preview)
Best Practices when using Microsoft Graph APIs platform capabilities (英語動画)

21
16
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
21
16

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?