במאמר הזה מפורטים התנאים שכל אישור בשרשרת X.509 צריך לעמוד בהם כדי שיוגדר כמהימן לשימוש באימייל מוצפן או באימייל שנחתם באמצעות S/MIME.
בנוסף לדרישות האלה, השרשרת צריכה להיות מעוגנת לאישור של רשות אישורים (CA) ש-Google סומכת עליה במפורש למטרה הזו. אפשר גם לבחור לקבל אישורי בסיס מרשויות אישורים שאתם סומכים עליהן. למידע נוסף, אפשר לעיין בהנחיות בנושא אישורי בסיס.
הערות:
- Google מספקת רשימה של אישורי CA שמוגדרים כמהימנים ב-Gmail לשימוש ב-S/MIME, וגם מתחזקת אותה. רשימת הרשויות להנפקת אישורים (CA) מהימנה אך ורק על פי שיקול דעתה של Google. Google שומרת לעצמה את הזכות להסיר רשויות אישורים בסיסיות בכל שלב ללא הודעה מוקדמת.
- מוודאים שהתוספים המותקנים לא סותרים תוספים אחרים באותו אישור. לדוגמה, אם מוגדרים nsCertTypes, הם צריכים לכסות את אותם שימושים בדיוק כמו התוסף key usage, התוסף extended key usage והתוסף basic constraints.
כללים לשרשרת אישורים
רשות אישורים (CA) עליונה
| שדה | ערך |
|---|---|
|
שם דומיין של המנפיק |
צריך לזהות את רשות האישורים (CA). לדוגמה, ה-DN לא יכול להיות ערך כללי כמו 'רשות אישורים'. |
|
Subject DN |
הטופס המקודד חייב להיות זהה בבייט ל-DN של המנפיק. |
|
פרטי מפתח ציבורי של נושא |
rsaEncryption עם מודול RSA של 2048, 3072 או 4096. או ecPublicKey באמצעות secp256r1 או secp384r1. |
אישורי ביניים של CA שאינם מה-CA המנפיק
אפשר להשתמש במידע הזה אם יש יותר מ-CA ביניים אחד בין שורש ה-CA לבין ישות הקצה, באופן ישיר או עקיף.
רשות האישורים ברמת הביניים שמנפיקה את האישור היא רשות האישורים ברמת הביניים שמנפיקה את האישור של ישות הקצה. הסעיף הזה רלוונטי לכל רשויות אישורים ברמת הביניים בשרשרת, מלבד רשות האישורים ברמת הביניים שהנפיקה את האישור.
| שדה | ערך | ||
|---|---|---|---|
| גרסה | גרסה 3 | ||
| מספר סידורי | הערך חייב להיות גדול מאפס (0). כשמבצעים קידוד DER כמספר שלם, הערך חייב להיות קטן מ-20 בייטים או שווה לו. | ||
| אלגוריתם חתימה | RSA עם SHA‐256, SHA‐384 או SHA‐512. או ECDSA עם SHA‐256, SHA‐384 או SHA‐512 | ||
| שם דומיין של המנפיק |
הערך חייב להיות זהה לחלוטין לערך של Subject DN של רשות האישורים המנפיקה. |
||
| תקופת תוקף | ללא תנאי | ||
| Subject DN | ללא תנאי | ||
| פרטי מפתח ציבורי של נושא |
rsaEncryption עם מודול RSA של 2048, 3072 או 4096. או ecPublicKey באמצעות secp256r1 או secp384r1 |
||
| תוסף | נוכחות | קריטי | ערך |
| שימוש במפתח | חובה | כן |
צריך להגדיר את מיקומי הביטים עבור: keyCertSign |
| מגבלות בסיסיות | חובה | כן | השדה cA צריך להיות מוגדר כ-true צריך לכלול את השדה pathLenConstraint |
| נקודות הפצה של CRL | חובה | לא |
צריך לציין לפחות מזהה משאב אחיד (URI) אחד של HTTP |
| (הערה) | שרתי ביטול צריכים לעמוד בדרישות הבאות של מדיניות האישורים של CA/Browser Forum Baseline Requirements בנושא הנפקה וניהול של אישורים מהימנים לציבור, גרסה 1.3.2 ואילך:
|
||
| תוספים אחרים | יכול להיות שקיים | ||
אישור ביניים של רשות אישורים שמנפיקה את ישות הקצה
חשוב: בשרשרת צריך להיות לפחות אישור ביניים אחד של רשות אישורים (CA). כלומר, אישור הבסיס לא יכול להנפיק ישירות אישורים של ישויות קצה.
| שדה | ערך | ||
|---|---|---|---|
| גרסה | גרסה 3 | ||
| מספר סידורי | הערך חייב להיות גדול מאפס (0), וכשהוא מקודד ב-DER כמספר שלם, הוא צריך להיות קטן מ-20 בייט או שווה לו. | ||
| אלגוריתם חתימה |
RSA עם SHA‐256, SHA‐384 או SHA‐512. או ECDSA עם SHA‐256, SHA‐384 או SHA‐512. |
||
| שם דומיין של המנפיק |
הערך חייב להיות זהה לחלוטין לערך של Subject DN של רשות האישורים המנפיקה. |
||
| תקופת תוקף |
ההבדל בין notBefore לבין notAfter התקופה לא יכולה להיות ארוכה מ-10 שנים, ולא יכולה להיות ארוכה מ-20 שנים. |
||
| Subject DN |
צריך לציין את השימוש ב-CA. |
||
| פרטי מפתח ציבורי של נושא |
rsaEncryption עם מודול RSA של 2048, 3072 או 4096. או ecPublicKey באמצעות secp256r1 או secp384r1 |
||
| תוסף | נוכחות | קריטי | ערך |
| שימוש במפתח | חובה | כן |
צריך להגדיר את מיקומי הביטים עבור: אסור להגדיר מיקומי ביטים אחרים |
| שימוש מורחב במפתח | חובה | אחד מהם | חייב להיות נוכח: emailProtection אסור להיות נוכח: serverAuth codeSigning timeStamping anyExtendedKeyUsage |
|
מגבלות בסיסיות |
חובה | כן |
השדה cA צריך להיות מוגדר כ-true |
| מדיניות אישורים | אופציונלי | לא |
צריך לספק policyIdentifier שמזהה את המדיניות שלפיה פועלת רשות האישורים (CA), והוא לא יכול להיות anyPolicy. |
| נקודות הפצה של CRL | חובה | לא |
צריך לציין לפחות מזהה משאב אחיד (URI) אחד של HTTP |
| (הערה) |
שרתי ביטול צריכים לפעול בהתאם לסעיפים הבאים של מדיניות האישורים של CA/Browser Forum Baseline Requirements בנושא הנפקה וניהול של אישורים מהימנים לציבור, גרסה 1.3.2 ואילך:
|
||
| תוספים אחרים | אופציונלי | לא |
יכול להיות שיופיע. |
אישור של ישות קצה
| שדה | ערך | ||
|---|---|---|---|
| גרסה | גרסה 3 | ||
| מספר סידורי |
הערך חייב להיות גדול מאפס (0) ולהכיל לפחות 64 ביטים בלתי צפויים. הערה: המאמר הזה יעודכן בהתאם לדרישות האנטרופיה של המספר הסידורי של ישות הקצה שמופיעות במדיניות האישורים של CA/Browser Forum Baseline Requirements. |
||
| אלגוריתם חתימה | RSA עם SHA‐256, SHA‐384 או SHA‐512. או ECDSA עם SHA‐256, SHA‐384 או SHA‐512. | ||
| שם דומיין של המנפיק |
הערך חייב להיות זהה לחלוטין לערך של Subject DN של רשות האישורים המנפיקה. |
||
| תקופת תוקף |
ההפרש בין התאריכים notBefore ו-notAfter לא יכול להיות ארוך מ-27 חודשים. השעה שמוגדרת ב-notBefore צריכה להיות השעה של החתימה, בתוספת או בניכוי של 48 שעות. |
||
| Subject DN |
כל שמות מובחנים יחסיים של נושאים, מלבד כתובת אימייל, חייבים לעבור אימות קפדני לפני הנפקתם, באמצעות הליך שמתועד ונבדק באופן ציבורי. הליך מקובל מפורט בקטע 3.2.3 'אימות של זהות אישית' במדיניות האישורים של CA/Browser Forum בנושא הנפקה וניהול של אישורים מהימנים לציבור, גרסה 1.3.2 ואילך. כל כתובות האימייל (לדוגמה, בשדות commonName או emailAddress) צריכות להופיע גם בתוסף Subject Alternate Name בתור rfc822Name. |
||
| פרטי מפתח ציבורי של נושא |
rsaEncryption עם מודול RSA של 2048, 3072 או 4096. או ecPublicKey באמצעות secp256r1 או secp384r1 |
||
| תוסף | נוכחות | קריטי | ערך |
| שימוש במפתח (RSA) | חובה | כן |
צריך להגדיר את מיקומי הביטים עבור: אסור להגדיר מיקומי ביטים אחרים. |
| שימוש במפתח (ECDH) | חובה |
חובה להגדיר את מיקומי הביטים עבור: אסור להגדיר מיקומי ביטים אחרים. |
|
| שימוש מורחב במפתח | חובה | אחד מהם |
חובה שיהיה קיים: |
|
מגבלות בסיסיות |
אופציונלי | אחד מהם |
אם השדה הזה קיים, השדה cA לא יכול להיות מוגדר כ-true |
| מדיניות אישורים | חובה | לא |
חובה: צריך לספק policyIdentifier שמזהה את המדיניות שלפיה הונפק האישור, ואסור שיהיה anyPolicy. יכול להיות שיהיה קיים: cps. אם הוא קיים, הוא חייב להכיל קישור HTTP או HTTPS תקין למדיניות ה-CPS שבה הונפק האישור. |
|
גישה לפרטי רשות |
אופציונלי | לא |
הפרמטרים caIssuers ו-ocsp, אם הם קיימים, חייבים להכיל לפחות מזהה משאב אחיד (URI) של HTTP שזמין לציבור. השדה AccessDescription לא יכול להכיל תוויות או פרמטרים שספציפיים לאישור מסוים. |
| נקודות הפצה של CRL | חובה | לא |
צריך לציין לפחות מזהה משאב אחיד (URI) ל-HTTP |
|
(הערה) |
שרתי ביטול צריכים לפעול בהתאם לסעיפים הבאים של מדיניות האישורים של CA/Browser Forum Baseline Requirements בנושא הנפקה וניהול של אישורים מהימנים לציבור, גרסה 1.3.2 ואילך:
|
||
|
שם חלופי של בעלים (subject) |
חובה | לא |
חייב להכיל לפחות פריט אחד מהסוג rfc822Name. |
|
תוספים אחרים |
אופציונלי | לא | יכול להיות שיופיע. |