إدارة الأسماء المستعارة

تمثل الأسماء المستعارة لميزة "إرسال كـ" عناوين البريد الإلكتروني التي يمكن للحساب إرسال بريد منها. يحتوي كل حساب دائمًا على اسم مستعار واحد على الأقل لتمثيل عنوان البريد الإلكتروني الأساسي للحساب.

تتوافق الأسماء المستعارة لميزة "إرسال كـ" مع ميزة "إرسال البريد كـ" في واجهة الويب.

كما يتم استخدام الأسماء المستعارة أيضًا لإدارة التوقيعات للحساب. يعتبر الفهم الأساسي للأسماء المستعارة "إرسال كـ" مطلوبًا لتتمكن من تغيير توقيعات البريد الإلكتروني. يوضح لك الفيديو أعلاه كيفية إجراء تكرار حلقي للأسماء المستعارة لإرسال كـ وتعديل التوقيع لعنوان البريد الإلكتروني الرئيسي للمستخدم.

للحصول على معلومات حول كيفية إنشاء الأسماء المستعارة أو إدراجها أوالحصول عليها أو تحديثها أو حذفها، يمكنك الاطّلاع على SendAs المرجع.

إنشاء الأسماء المستعارة والتحقق منها

يجب إنشاء أسماء مستعارة قبل استخدامها. وفي بعض الحالات، على المستخدمين أيضًا إثبات ملكية العنوان البديل للبريد الإلكتروني.

إذا تطلبت خدمة Gmail التحقق من المستخدم لعنوان بديل، سيتم عرض العنوان البديل مع الحالة pending. يتم إرسال رسالة تحقق تلقائيًا إلى عنوان البريد الإلكتروني المستهدف. يجب على مالك عنوان البريد الإلكتروني إكمال عملية إثبات الملكية قبل أن يتم استخدامه.

إنّ حالة إثبات ملكية الأسماء المستعارة التي لا تتطلب إثبات الملكية هي accepted.

يمكنك استخدام طريقة إثبات الملكية لإعادة إرسال طلب إثبات الملكية إذا لزم الأمر.

إعدادات SMTP

يجب أن ترسل الأسماء المستعارة للعناوين الخارجية البريد من خلال وكيل إرسال بريد SMTP بعيد (MSA). لضبط اتفاقية الخدمة الرئيسية (MSA) عبر SMTP لعنوان بديل، استخدِم الحقل smtpMsa لتقديم تفاصيل الاتصال.

إدارة التوقيعات

ويمكنك أيضًا ضبط توقيعات البريد الإلكتروني لكل اسم مستعار. على سبيل المثال، لتعيين التوقيع للعنوان الأساسي للمستخدم:

Java

gmail/snippets/src/main/java/UpdateSignature.java
import com.google.api.client.googleapis.json.GoogleJsonError;
import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.http.javanet.NetHttpTransport;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.services.gmail.Gmail;
import com.google.api.services.gmail.GmailScopes;
import com.google.api.services.gmail.model.ListSendAsResponse;
import com.google.api.services.gmail.model.SendAs;
import com.google.auth.http.HttpCredentialsAdapter;
import com.google.auth.oauth2.GoogleCredentials;
import java.io.IOException;

/* Class to demonstrate the use of Gmail Update Signature API */
public class UpdateSignature {
  /**
   * Update the gmail signature.
   *
   * @return the updated signature id , {@code null} otherwise.
   * @throws IOException - if service account credentials file not found.
   */
  public static String updateGmailSignature() throws IOException {
        /* Load pre-authorized user credentials from the environment.
           TODO(developer) - See https://developers.google.com/identity for
            guides on implementing OAuth2 for your application. */
    GoogleCredentials credentials = GoogleCredentials.getApplicationDefault()
        .createScoped(GmailScopes.GMAIL_SETTINGS_BASIC);
    HttpRequestInitializer requestInitializer = new HttpCredentialsAdapter(credentials);

    // Create the gmail API client
    Gmail service = new Gmail.Builder(new NetHttpTransport(),
        GsonFactory.getDefaultInstance(),
        requestInitializer)
        .setApplicationName("Gmail samples")
        .build();

    try {
      SendAs primaryAlias = null;
      ListSendAsResponse aliases = service.users().settings().sendAs().list("me").execute();
      for (SendAs alias : aliases.getSendAs()) {
        if (alias.getIsPrimary()) {
          primaryAlias = alias;
          break;
        }
      }
      // Updating a new signature
      SendAs aliasSettings = new SendAs().setSignature("Automated Signature");
      SendAs result = service.users().settings().sendAs().patch(
              "me",
              primaryAlias.getSendAsEmail(),
              aliasSettings)
          .execute();
      //Prints the updated signature
      System.out.println("Updated signature - " + result.getSignature());
      return result.getSignature();
    } catch (GoogleJsonResponseException e) {
      // TODO(developer) - handle error appropriately
      GoogleJsonError error = e.getDetails();
      if (error.getCode() == 403) {
        System.err.println("Unable to update signature: " + e.getDetails());
      } else {
        throw e;
      }
    }
    return null;
  }
}

Python

gmail/snippet/settingssnippet/update_signature.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError


def update_signature():
  """Create and update signature in gmail.
  Returns:Draft object, including updated signature.

  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """
  creds, _ = google.auth.default()

  try:
    # create gmail api client
    service = build("gmail", "v1", credentials=creds)

    primary_alias = None

    # pylint: disable=E1101
    aliases = service.users().settings().sendAs().list(userId="me").execute()
    for alias in aliases.get("sendAs"):
      if alias.get("isPrimary"):
        primary_alias = alias
        break

    send_as_configuration = {
        "displayName": primary_alias.get("sendAsEmail"),
        "signature": "Automated Signature",
    }

    # pylint: disable=E1101
    result = (
        service.users()
        .settings()
        .sendAs()
        .patch(
            userId="me",
            sendAsEmail=primary_alias.get("sendAsEmail"),
            body=send_as_configuration,
        )
        .execute()
    )
    print(f'Updated signature for: {result.get("displayName")}')

  except HttpError as error:
    print(f"An error occurred: {error}")
    result = None

  return result.get("signature")


if __name__ == "__main__":
  update_signature()