このドキュメントは、非推奨となった Email Settings API から Gmail API へのアプリの移行に役立ちます。
リクエストの承認
Email Settings API と同様に、Gmail API は OAuth 2.0 プロトコルを使用してリクエストを承認します。主な違いは、Gmail API の権限がドメイン全体ではなく個々のユーザーにスコープ設定されることです。つまり、ドメイン管理者アカウントを承認しても、ドメイン内の他のユーザーのメールを移行することはできません。代わりに、Google 管理コンソールの許可リストに追加されたドメイン全体の権限を持つ標準サービス アカウントを使用して、適切な認証トークンを生成する必要があります。
Email Settings API は次のスコープを使用していました。
https://apps-apis.google.com/a/feeds/emailsettings/2.0/
Gmail API の同等のスコープは次のとおりです。
https://www.googleapis.com/auth/gmail.settings.basic
https://www.googleapis.com/auth/gmail.settings.sharing
プロトコルの変更
Email Settings API は XML ベースの GDATA プロトコルを使用します。Gmail API は JSON を使用します。設定は主にキーと値のペアで構成されているため、ペイロードはバージョン間で概念的に類似しています。
ラベルの作成例:
Email Settings API
POST https://apps-apis.google.com/a/feeds/emailsettings/2.0/{domain name}/{username}/label
<?xml version="1.0" encoding="utf-8"?>
<atom:entry xmlns:atom="http://www.w3.org/2005/Atom" xmlns:apps="http://schemas.google.com/apps/2006">
<apps:property name="label" value="status updates" />
</atom:entry>
Gmail API
POST https://www.googleapis.com/gmail/v1/users/{username}/labels
{
"name": "status updates"
}
プロトコルを直接実装するのではなく、提供されているクライアント ライブラリを使用します。
ラベルを管理
Gmail API でラベルを管理するには、labels リソースを使用します。
| 以前の設定 | 新しい設定 | メモ |
|---|---|---|
| labelId | id | |
| ラベル | name | |
| unreadCount | messagesUnread | |
| visibility | labelListVisibility | SHOW は labelShow になりました。HIDE は labelHide になりました |
その他の変更点:
- ラベルを更新または削除する場合、Gmail API は名前ではなく ID でラベルを参照します。
フィルタを管理
Gmail API でフィルタを管理するには、settings.filters リソースを使用します。
| 以前の設定 | 新しい設定 | メモ |
|---|---|---|
| from | criteria.from | |
| に | criteria.to | |
| 件名 | criteria.subject | |
| hasTheWord | criteria.query | |
| doesNotHaveTheWord | criteria.negatedQuery | |
| hasAttachment | criteria.hasAttachment | |
| shouldArchive | action.removeLabelIds | ラベル ID として INBOX を使用する |
| shouldMarkAsRead | action.removeLabelIds | ラベル ID として UNREAD を使用する |
| shouldStar | action.addLabelIds | ラベル ID として STARRED を使用する |
| ラベル | action.addLabelIds | 追加するラベルの ID を使用する |
| forwardTo | action.forward | |
| shouldTrash | action.addLabelIds | ラベル ID として TRASH を使用する |
| neverSpam | action.removeLabelIds | ラベル ID として SPAM を使用する |
その他の変更点:
- ユーザーラベルの追加がまだ存在しない場合は、
labels.createメソッドを使用して明示的に作成する必要があります。
送信専用エイリアスを管理する
Gmail API で送信専用エイリアスを管理するには、settings.sendAs リソースを使用します。
| 以前の設定 | 新しい設定 |
|---|---|
| name | displayName |
| 住所 | sendAsEmail |
| replyTo | replyToAddress |
| makeDefault | isDefault |
ウェブクリップを管理する
Gmail API ではウェブクリップの設定は使用できません。
自動転送を管理する
Gmail API で自動転送を管理するには、settings リソースを使用します。
| 以前の設定 | 新しい設定 | メモ |
|---|---|---|
| 有効にする | 有効 | |
| forwardTo | emailAddress | |
| アクション | disposition | KEEP は leaveInInbox になりましたARCHIVE は archive になりましたDELETE は trash になりましたMARK_READ は markRead になりました |
その他の変更点:
- 転送先アドレスは、使用する前に作成して確認する必要があります。
- 転送アドレスは、
settings.forwardingAddressesリソースを使用して管理できます。
POP 設定を管理する
Gmail API で POP アクセスを管理するには、settings リソースを使用します。
| 以前の設定 | 新しい設定 | メモ |
|---|---|---|
| 有効にする | accessWindow | disabled に設定すると無効になります |
| enableFor | accessWindow | ALL_MAIL は allMail になりました。MAIL_FROM_NOW_ON は fromNowOn になりました |
| アクション | disposition | KEEP は leaveInInbox になりましたARCHIVE は archive になりましたDELETE は trash になりましたMARK_READ は markRead になりました |
IMAP 設定を管理する
Gmail API で IMAP アクセスを管理するには、settings リソースを使用します。
| 以前の設定 | 新しい設定 |
|---|---|
| 有効にする | 有効 |
不在通知の自動返信設定を管理する
Gmail API で不在通知の自動返信を管理するには、settings リソースを使用します。
| 以前の設定 | 新しい設定 |
|---|---|
| contactsOnly | restrictToContacts |
| domainOnly | restrictToDomain |
| 有効にする | enableAutoReply |
| endDate | endTime |
| メッセージ | responseBodyHtml responseBodyPlainText |
| startDate | startTime |
| 件名 | responseSubject |
署名設定を管理する
Gmail API でメール署名を管理するには、settings.sendAs リソースを使用します。
| 以前の設定 | 新しい設定 |
|---|---|
| signature | signature |
その他の変更点:
- 署名はエイリアスごとに管理されるようになりました。
言語設定を管理する
Gmail API で言語設定を管理するには、settings リソースを使用します。
| 以前の設定 | 新しい設定 |
|---|---|
| language | displayLanguage |
詳しくは、言語設定を管理するをご覧ください。
委任の設定を管理する
Gmail API で委任を管理するには、settings.delegates リソースを使用します。
| 以前の設定 | 新しい設定 |
|---|---|
| 住所 | delegateEmail |
| ステータス | verificationStatus |
その他の変更点:
- 全般
- 委任方法(
settings.delegates.createを含む)を使用するには、委任元ユーザーの Gmail が有効になっている必要があります。たとえば、委任ユーザーを Google Workspace で一時停止することはできません。 - 新しいメソッドのいずれにも、メール エイリアスを委任メールの入力として使用することはできません。委任ユーザーは、メインのメールアドレスで参照する必要があります。
- 委任方法(
settings.delegates.create- この方法を使用して、同じ Google Workspace 組織に属する複数のドメイン間で委任関係を作成できるようになりました。
- このメソッドは、次回ログイン時にパスワードの変更が必要なユーザーにも使用できるようになりました。
- 成功した場合、このメソッドは空のレスポンス本文ではなく、レスポンス本文で
settings.delegatesリソースを返します。 - 委任者または委任先のユーザーのいずれかが無効になっている場合(Google Workspace で一時停止されている場合など)、このメソッドは HTTP 500 エラーではなく HTTP 4XX エラーで失敗します。
settings.delegates.delete- このメソッドを使用して、
acceptedまたはexpiredの代理人だけでなく、任意のVerificationStatusを持つ代理人を削除できるようになりました。
- このメソッドを使用して、
settings.delegates.get- これは新しいメソッドであり、必要に応じて
settings.delegates.listメソッドよりも望ましい場合があります。
- これは新しいメソッドであり、必要に応じて
全般的な設定を管理
Gmail API では全般設定を使用できません。