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

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

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

تُستخدَم الأسماء البديلة أيضًا لإدارة التوقيعات لحساب معيّن. يجب أن يكون لديك فهم أساسي للأسماء البديلة لميزة "الإرسال باسم" حتى تتمكّن من تغيير التوقيعات في الرسائل الإلكترونية. يوضِّح لك الفيديو أعلاه كيفية تكرار العناوين البديلة للبريد الإلكتروني وتعديل التوقيع لعنوان البريد الإلكتروني الرئيسي للمستخدم.

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

إنشاء الأسماء البديلة وتأكيدها

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

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

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

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

إعدادات بروتوكول SMTP

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

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

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

JavaPython
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;
  }
}
gmail/snippet/settings snippets/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()