בדף הזה מוסבר איך להשתמש באילוצים מותאמים אישית של Organization Policy Service כדי להגביל פעולות ספציפיות במשאבים הבאים של Google Cloud :
iam.googleapis.com/AllowPolicy
מידע נוסף על מדיניות הארגון זמין במאמר בנושא מדיניות ארגונית בהתאמה אישית.
מידע על מדיניות הארגון ומגבלות
Google Cloud שירות של מדיניות הארגון מאפשר לכם לקבל שליטה מרוכזת ופרוגרמטית על המשאבים של הארגון. בתור אדמינים של מדיניות הארגון, אתם יכולים להגדיר מדיניות ארגונית, שהיא קבוצה של הגבלות שנקראות אילוצים שחלות על משאבים ב-Google Cloud ועל משאבים שנגזרים מהם בGoogle Cloud היררכיית המשאבים. אפשר לאכוף את מדיניות הארגון ברמת הארגון, התיקייה או הפרויקט.
ב-Organization Policy יש אילוצים מנוהלים מובנים לשירותים שונים של Google Cloud . עם זאת, אם אתם רוצים שליטה מדויקת יותר בשדות הספציפיים שמוגבלים במדיניות הארגון, אתם יכולים גם ליצור אילוצים בהתאמה אישית ולהשתמש בהם במדיניות הארגון.
העברה בירושה של מדיניות
כברירת מחדל, מדיניות הארגון עוברת בירושה לצאצאים של המשאבים שבהם אתם אוכפים את המדיניות. לדוגמה, אם אוכפים מדיניות בתיקייה, Google Cloud המדיניות נאכפת בכל הפרויקטים בתיקייה. מידע נוסף על ההתנהגות הזו ועל שינוי שלה זמין במאמר בנושא כללי הערכה היררכיים.
יתרונות
אתם יכולים להשתמש במדיניות ארגונית מותאמת אישית שמפנה למאפייני IAM כדי לשלוט באופן שבו אפשר לשנות את כללי מדיניות ההרשאה. באופן ספציפי, אתם יכולים לשלוט בפרטים הבאים:
- למי אפשר להקצות תפקידים
- מי יכול לבטל את התפקידים שלו
- אילו תפקידים אפשר להקצות
- אילו תפקידים אפשר לבטל
לדוגמה, אתם יכולים למנוע הקצאה של תפקידים שמכילים את המילה admin לחשבונות משתמשים שכתובות האימייל שלהם מסתיימות ב-@gmail.com.
מגבלות
יש כמה מגבלות על מדיניות ארגונית בהתאמה אישית במצב הרצה יבשה שמתייחסת למאפייני IAM. כלומר, יכול להיות שביומני ביקורת על הפרות שקשורות ל-method
setIamPolicyיחסרו השדות הבאים:resourceNameserviceNamemethodName
לא נוצרים יומני ביקורת לכל ההפרות של מדיניות ארגונית מותאמת אישית שקשורות ל-IAM. כלומר, אם מדיניות ארגונית מותאמת אישית גורמת לכך שפעולת
setIamPolicyבמשאב הארגון תיכשל, אזGoogle Cloud לא יוצר יומן ביקורת לאירוע הזה.מדיניות ארגונית בהתאמה אישית שמפנה למאפייני IAM לא משפיעה על:
- ההרשאות שמוענקות כברירת מחדל על ידי רשימות ACL ב-Cloud Storage.
- הענקת תפקידים אוטומטית לערכי נוחות ב-Cloud Storage ולגישה למערך הנתונים שמוגדר כברירת מחדל ב-BigQuery.
- תפקידים שמוענקים על ידי מדיניות הרשאות שמוגדרת כברירת מחדל – לדוגמה, יוצר פרויקט שמקבל אוטומטית את התפקיד 'בעלים' (
roles/owner) בפרויקט.
אפשר לשלוח למשתמשים הזמנות להפוך לבעלים, גם אם יש לכם מדיניות ארגונית בהתאמה אישית שמונעת את ההענקה של תפקיד הבעלים (
roles/owner). עם זאת, מדיניות הארגון המותאמת אישית לא מונעת את שליחת ההזמנה, אבל היא מונעת מהמשתמשים המוזמנים לקבל את תפקיד הבעלים. אם משתמשים מוזמנים ינסו לאשר את ההזמנה, הם ייתקלו בשגיאה ולא יקבלו את תפקיד הבעלים.פעולות מסוימות ב- Google Cloud, כמו יצירת משאבים או הפעלת ממשקי API, כוללות הענקת תפקיד אוטומטית לסוכן שירות או לחשבון שירות שמוגדר כברירת מחדל. אם פעולה מסוימת כוללת הענקה אוטומטית של תפקיד, ומדיניות ארגונית מונעת את הענקת התפקיד הזה, יכול להיות שהפעולה כולה תיכשל.
אם נתקלתם בבעיה הזו, אתם יכולים להשתמש בתגים כדי להשבית באופן זמני את ההגבלה שמונעת את הקצאת התפקיד. לאחר מכן, מבצעים את הפעולה. אחרי שהפעולה מסתיימת, מפעילים מחדש את ההגבלה.
לפני שמתחילים
-
אם רוצים לבדוק כללי מדיניות ארגוניים בהתאמה אישית שמפנים למשאבי IAM, צריך ליצור פרויקט חדש. בדיקה של מדיניות הארגון הזו בפרויקט קיים עלולה לשבש את תהליכי העבודה של האבטחה.
-
In the Google Cloud console, go to the project selector page.
-
Select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
התפקידים הנדרשים
כדי לקבל את ההרשאות שדרושות לניהול כללי מדיניות הארגון, צריך לבקש מהאדמין להקצות לכם את תפקידי ה-IAM הבאים:
-
Organization Policy Administrator (
roles/orgpolicy.policyAdmin) בארגון -
כדי לבדוק את מדיניות הארגון שמתוארת בדף הזה:
אדמין IAM של פרויקט (
roles/resourcemanager.projectIamAdmin) בפרויקט
להסבר על מתן תפקידים, ראו איך מנהלים את הגישה ברמת הפרויקט, התיקייה והארגון.
התפקידים המוגדרים מראש האלה כוללים את ההרשאות שנדרשות לניהול מדיניות הארגון. כדי לראות בדיוק אילו הרשאות נדרשות, אפשר להרחיב את הקטע ההרשאות הנדרשות:
ההרשאות הנדרשות
כדי לנהל את מדיניות הארגון, נדרשות ההרשאות הבאות:
-
orgpolicy.*בארגון -
בודקים את מדיניות הארגון שמתוארת בדף הזה:
resourcemanager.projects.setIamPolicyבפרויקט
יכול להיות שתקבלו את ההרשאות האלה באמצעות תפקידים בהתאמה אישית או תפקידים מוגדרים מראש אחרים.
הגדרת אילוץ בהתאמה אישית
אילוץ בהתאמה אישית מוגדר בקובץ YAML לפי המשאבים, השיטות, התנאים והפעולות שנתמכים על ידי השירות שבו אתם אוכפים את מדיניות הארגון. התנאים להגבלות המותאמות אישית מוגדרים באמצעות Common Expression Language (CEL). מידע נוסף על יצירת תנאים באילוצים מותאמים אישית באמצעות CEL זמין בקטע על CEL במאמר יצירה וניהול של אילוצים מותאמים אישית.
המסוף
כדי ליצור אילוץ בהתאמה אישית:
- במסוף Google Cloud , נכנסים לדף מדיניות הארגון.
- בבורר הפרויקטים, בוחרים את הפרויקט שרוצים להגדיר לו את מדיניות הארגון.
- לוחצים על Custom constraint (הגבלה מותאמת אישית).
- בתיבה שם לתצוגה, מזינים שם שאנשים יכולים לקרוא למגבלה. השם הזה משמש בהודעות שגיאה, ואפשר להשתמש בו לצורך זיהוי וניפוי באגים. אל תשתמשו בפרטים אישיים מזהים (PII) או במידע אישי רגיש בשמות המוצגים, כי השם הזה עלול להיחשף בהודעות שגיאה. השדה הזה יכול להכיל עד 200 תווים.
-
בתיבה מזהה האילוץ, מזינים את השם שרוצים לתת לאילוץ המותאם אישית החדש. אילוץ מותאם אישית יכול להכיל רק אותיות (כולל אותיות גדולות וקטנות) או מספרים, למשל
custom.disableGkeAutoUpgrade. השדה הזה יכול להכיל עד 70 תווים, לא כולל הקידומת (custom.), לדוגמה,organizations/123456789/customConstraints/custom. אל תכללו פרטים אישיים מזהים (PII) או מידע אישי רגיש במזהה האילוץ, כי הם עלולים להיחשף בהודעות שגיאה. - בתיבה Description, מזינים תיאור קריא לאנשים של האילוץ. התיאור הזה משמש כהודעת שגיאה כשמתבצעת הפרה של המדיניות. לכלול פרטים על הסיבה להפרת המדיניות ואיך לפתור אותה. אל תכללו בתיאור פרטים אישיים מזהים (PII) או מידע אישי רגיש, כי הם עלולים להיחשף בהודעות שגיאה. השדה הזה יכול להכיל עד 2,000 תווים.
-
בתיבה Resource type, בוחרים את השם של משאב REST Google Cloud שמכיל את האובייקט והשדה שרוצים להגביל – לדוגמה,
container.googleapis.com/NodePool. רוב סוגי המשאבים תומכים בעד 20 אילוצים מותאמים אישית. אם תנסו ליצור עוד אילוצים בהתאמה אישית, הפעולה תיכשל. - בקטע שיטת אכיפה, בוחרים אם לאכוף את ההגבלה על שיטת REST CREATE או על השיטות CREATE ו-UPDATE. אם אוכפים את המגבלה באמצעות השיטה UPDATE על משאב שמפר את המגבלה, מדיניות הארגון חוסמת שינויים במשאב הזה, אלא אם השינוי פותר את ההפרה.
- כדי להגדיר תנאי, לוחצים על Edit condition.
-
בחלונית Add condition, יוצרים תנאי CEL שמתייחס למשאב שירות נתמך, לדוגמה,
resource.management.autoUpgrade == false. השדה הזה יכול להכיל עד 1,000 תווים. פרטים על השימוש ב-CEL זמינים במאמר בנושא Common Expression Language. מידע נוסף על משאבי השירות שאפשר להשתמש בהם באילוצים בהתאמה אישית זמין במאמר שירותים שתומכים באילוצים בהתאמה אישית. - לוחצים על Save.
- בקטע פעולה, בוחרים אם לאשר או לדחות את השיטה שנבדקה אם התנאי מתקיים.
- לוחצים על יצירת אילוץ.
לא כל השירותים של Google Cloud תומכים בשתי השיטות. כדי לראות את השיטות הנתמכות לכל שירות, צריך לחפש את השירות בקטע שירותים נתמכים.
הפעולה deny (דחייה) פירושה שהפעולה ליצירה או לעדכון של המשאב נחסמת אם התנאי מחזיר את הערך true.
הפעולה allow (אישור) פירושה שהפעולה ליצירה או לעדכון של המשאב מותרת רק אם התנאי מחזיר את הערך true. כל מקרה אחר, מלבד אלה שמפורטים במפורש בתנאי, נחסם.
אחרי שמזינים ערך בכל שדה, מופיעה משמאל הגדרת ה-YAML המקבילה למגבלה המותאמת אישית הזו.
gcloud
- כדי ליצור אילוץ בהתאמה אישית, יוצרים קובץ YAML בפורמט הבא:
-
ORGANIZATION_ID: מזהה הארגון, למשל123456789. -
CONSTRAINT_NAME: השם שרוצים לתת לאילוץ המותאם אישית החדש. אילוץ מותאם אישית יכול להכיל רק אותיות (כולל אותיות רישיות וקטנות) או מספרים, למשל,custom.denyProjectIAMAdmin. השדה הזה יכול להכיל עד 70 תווים. -
RESOURCE_NAME: השם המוגדר במלואו של המשאב Google Cloud שמכיל את האובייקט והשדה שרוצים להגביל. לדוגמה:iam.googleapis.com/AllowPolicy. -
CONDITION: תנאי CEL שנכתב על סמך ייצוג של משאב שירות נתמך. השדה הזה יכול להכיל עד 1,000 תווים. לדוגמה:.resource.bindings.exists(binding, RoleNameMatches(binding.role, ['roles/resourcemanager.projectIamAdmin'])) -
ACTION: הפעולה שיש לבצע אם התנאיconditionמתקיים. הערכים האפשריים הםALLOWו-DENY. -
DISPLAY_NAME: שם קריא לאילוץ. השדה הזה יכול להכיל עד 200 תווים. -
DESCRIPTION: תיאור ידידותי למשתמש של האילוץ שיוצג כהודעת שגיאה אם המדיניות תופר. השדה הזה יכול להכיל עד 2,000 תווים. -
אחרי שיוצרים קובץ YAML לאילוץ חדש בהתאמה אישית, צריך להגדיר אותו כדי שיהיה זמין למדיניות הארגון בארגון שלכם. כדי להגדיר אילוץ בהתאמה אישית, משתמשים בפקודה
gcloud org-policies set-custom-constraint: -
כדי לוודא שהאילוץ המותאם אישית קיים, משתמשים בפקודה
gcloud org-policies list-custom-constraints:
name: organizations/ORGANIZATION_ID/customConstraints/CONSTRAINT_NAME resourceTypes: RESOURCE_NAME methodTypes: - CREATE
- UPDATE condition: "CONDITION" actionType: ACTION displayName: DISPLAY_NAME description: DESCRIPTION
מחליפים את מה שכתוב בשדות הבאים:
מידע נוסף על המשאבים שאפשר לכתוב תנאים לגביהם זמין במאמר משאבים נתמכים.
פעולת ההרשאה פירושה שאם התנאי מקבל את הערך True, הפעולה ליצירה או לעדכון של המשאב מותרת. המשמעות היא שכל מקרה אחר, מלבד זה שמופיע במפורש בתנאי, ייחסם.
הפעולה deny (דחייה) פירושה שאם התנאי מחזיר את הערך True, הפעולה ליצירה או לעדכון של המשאב נחסמת.
gcloud org-policies set-custom-constraint CONSTRAINT_PATH
מחליפים את CONSTRAINT_PATH בנתיב המלא לקובץ האילוצים המותאמים אישית. לדוגמה, /home/user/customconstraint.yaml.
אחרי שהפעולה הזו תושלם, ההגבלות המותאמות אישית יהיו זמינות כמדיניות ארגונית ברשימת Google Cloud מדיניות הארגון.
gcloud org-policies list-custom-constraints --organization=ORGANIZATION_ID
מחליפים את ORGANIZATION_ID במזהה של משאב הארגון.
מידע נוסף זמין במאמר בנושא צפייה במדיניות הארגון.
אכיפה של מדיניות ארגון מותאמת אישית
כדי לאכוף אילוץ, יוצרים מדיניות ארגון שמפנה אליו, ואז מחילים את מדיניות הארגון הזו על משאב Google Cloud .המסוף
- במסוף Google Cloud , נכנסים לדף מדיניות הארגון.
- בתפריט לבחירת פרויקט, בוחרים את הפרויקט שרוצים להגדיר לו את מדיניות הארגון.
- ברשימה בדף מדיניות הארגון, בוחרים את האילוץ כדי לראות את הדף פרטי המדיניות של האילוץ הזה.
- כדי להגדיר את מדיניות הארגון למשאב הזה, לוחצים על ניהול מדיניות.
- בדף עריכת מדיניות, בוחרים באפשרות במקום המדיניות של המשאב הראשי.
- לוחצים על Add a rule.
- בקטע Enforcement (אכיפה), בוחרים אם מדיניות הארגון הזו נאכפת או לא.
- אופציונלי: כדי להגדיר את מדיניות הארגון כתלויה בתג, לוחצים על הוספת תנאי. הערה: אם מוסיפים כלל מותנה למדיניות ארגון, צריך להוסיף לפחות כלל לא מותנה אחד, אחרת אי אפשר לשמור את המדיניות. מידע נוסף זמין במאמר הגדרת מדיניות ארגונית באמצעות תגים.
- כדי לאכוף את המדיניות של הארגון במצב הרצת בדיקה, לוחצים על הגדרת המדיניות להרצת בדיקה. מידע נוסף מופיע במאמר יצירת מדיניות ארגונית במצב הרצה יבשה.
- אחרי שמוודאים שמדיניות הארגון במצב הרצה יבשה פועלת כמו שרוצים, לוחצים על הגדרת מדיניות כדי להגדיר את המדיניות הפעילה.
gcloud
- כדי ליצור מדיניות ארגונית עם כללים בוליאניים, יוצרים קובץ YAML של מדיניות שמפנה לאילוץ:
-
PROJECT_ID: הפרויקט שבו רוצים לאכוף את האילוץ. -
CONSTRAINT_NAME: השם שהגדרתם לאילוץ המותאם אישית. לדוגמה,custom.denyProjectIAMAdmin. -
כדי לאכוף את מדיניות הארגון במצב הרצה יבשה, מריצים את הפקודה הבאה עם הדגל
dryRunSpec: -
אחרי שמוודאים שמדיניות הארגון במצב הרצה יבשה פועלת כמו שרוצים, מגדירים את המדיניות הפעילה באמצעות הפקודה
org-policies set-policyוהדגלspec:
name: projects/PROJECT_ID/policies/CONSTRAINT_NAME spec: rules: - enforce: true dryRunSpec: rules: - enforce: true
מחליפים את מה שכתוב בשדות הבאים:
gcloud org-policies set-policy POLICY_PATH --update-mask=dryRunSpec
מחליפים את POLICY_PATH בנתיב המלא לקובץ ה-YAML של מדיניות הארגון. יכולות לעבור עד 15 דקות עד שהמדיניות תיכנס לתוקף.
gcloud org-policies set-policy POLICY_PATH --update-mask=spec
מחליפים את POLICY_PATH בנתיב המלא לקובץ ה-YAML של מדיניות הארגון. יכולות לעבור עד 15 דקות עד שהמדיניות תיכנס לתוקף.
בדיקה של מדיניות הארגון המותאמת אישית
אופציונלי: אפשר לבדוק את מדיניות הארגון על ידי הגדרת המדיניות וניסיון לבצע פעולה שהמדיניות אמורה למנוע.
יצירת האילוץ
שומרים את הקובץ הבא בשם
constraint-deny-project-iam-admin.name: organizations/ORG_ID/customConstraints/custom.denyProjectIAMAdmin resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.exists( binding, RoleNameMatches(binding.role, ['roles/resourcemanager.projectIamAdmin']) && binding.members.exists(member, MemberSubjectMatches(member, ['user:EMAIL_ADDRESS']) ) )" actionType: DENY displayName: Do not allow EMAIL_ADDRESS to be granted the Project IAM Admin role.מחליפים את הערכים הבאים:
-
ORG_ID: המזהה המספרי שלGoogle Cloud הארגון. MEMBER_EMAIL_ADDRESS: כתובת האימייל של הגורם המרכזי שרוצים להשתמש בו כדי לבדוק את האילוץ המותאם אישית. בזמן שהאילוץ פעיל, אי אפשר להקצות לחשבון המשתמש הזה את התפקיד 'אדמין IAM בפרויקט' (roles/resourcemanager.projectIamAdmin) בפרויקט שבו האילוץ נאכף.
-
החלת האילוץ:
gcloud org-policies set-custom-constraint ~/constraint-deny-project-iam-admin.yamlמוודאים שהאילוץ קיים:
gcloud org-policies list-custom-constraints --organization=ORGANIZATION_ID
יצירת המדיניות
שומרים את הקובץ הבא בשם
policy-deny-project-iam-admin.yaml:name: projects/PROJECT_ID/policies/custom.denyProjectIamAdmin spec: rules: - enforce: trueמחליפים את
PROJECT_IDבמזהה הפרויקט.החלת המדיניות:
gcloud org-policies set-policy ~/policy-deny-project-iam-admin.yamlמוודאים שהמדיניות קיימת:
gcloud org-policies list --project=PROJECT_ID
אחרי שמחילים את המדיניות, מחכים כשתי דקות עד ש- Google Cloud יתחיל לאכוף את המדיניות.
בדיקת המדיניות
מנסים להקצות את התפקיד 'אדמין IAM בפרויקט' (roles/resourcemanager.projectIamAdmin) לחשבון המשתמש שכתובת האימייל שלו נכללה באילוץ המותאם אישית. לפני שמריצים את הפקודה, מחליפים את הערכים הבאים:
-
PROJECT_ID: המזהה של Google Cloud הפרויקט שבו נאכף האילוץ -
EMAIL_ADDRESS: כתובת האימייל של חשבון המשתמש שציינתם כשנוצר האילוץ של מדיניות הארגון.
gcloud projects add-iam-policy-binding PROJECT_ID \ --member=user:EMAIL_ADDRESS --role=roles/resourcemanager.projectIamAdmin
הפלט שיתקבל:
Operation denied by custom org policies: ["customConstraints/custom.denyProjectIAMAdmin": "EMAIL_ADDRESS can't be granted the Project IAM Admin role."]
דוגמאות למדיניות ארגון מותאמת אישית לתרחישי שימוש נפוצים
בטבלה הבאה מפורט התחביר של כמה אילוצים מותאמים אישית לתרחישי שימוש נפוצים.
בדוגמאות הבאות נעשה שימוש בפקודות המאקרו all ו-exists של CEL. מידע נוסף על פקודות מאקרו כאלה זמין במאמר פקודות מאקרו להערכת רשימות.
| תיאור | תחביר של אילוצים |
|---|---|
| לחסום את האפשרות להעניק תפקיד ספציפי. |
name: organizations/ORG_ID/customConstraints/custom.denyRole resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.exists( binding, RoleNameMatches(binding.role, ['ROLE']) )" actionType: DENY displayName: Do not allow the ROLE role to be granted |
| אפשר להעניק רק תפקידים ספציפיים. |
name: organizations/ORG_ID/customConstraints/custom.specificRolesOnly resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.all( binding, RoleNameMatches(binding.role, ['ROLE_1', 'ROLE_2']) )" actionType: ALLOW displayName: Only allow the ROLE_1 role and ROLE_2 role to be granted |
למנוע הקצאה של תפקידים שמתחילים ב-roles/storage..
|
name: organizations/ORG_ID/customConstraints/custom.dontgrantStorageRoles resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.exists( binding, RoleNameStartsWith(binding.role, ['roles/storage.']) )" actionType: DENY displayName: Prevent roles that start with "roles/storage." from being granted |
למנוע את ביטול ההרשאות של תפקידים עם admin בשם.
|
name: organizations/ORG_ID/customConstraints/custom.dontRevokeAdminRoles resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - REMOVE_GRANT condition: "resource.bindings.exists( binding, RoleNameContains(binding.role, ['admin']) )" actionType: DENY displayName: Prevent roles with "admin" in their names from being revoked |
| אפשר לאפשר רק לחשבונות משתמשים ספציפיים לקבל תפקידים. |
name: organizations/ORG_ID/customConstraints/custom.allowSpecificPrincipals resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.all( binding, binding.members.all(member, MemberSubjectMatches(member, ['user:USER','serviceAccount:SERVICE_ACCOUNT']) ) )" actionType: ALLOW displayName: Only allow roles to be granted to USER and SERVICE_ACCOUNT |
| למנוע ביטול של תפקידים בחשבונות ראשיים ספציפיים. |
name: organizations/ORG_ID/customConstraints/custom.denyRemovalOfSpecificPrincipals resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - REMOVE_GRANT condition: "resource.bindings.exists( binding, binding.members.exists(member, MemberSubjectMatches(member, ['user:USER_1','user:USER_2']) ) )" actionType: DENY displayName: Do not allow roles to be revoked from USER_1 or USER_2 |
למנוע מחשבונות משתמשים עם כתובות אימייל שמסתיימות ב-@gmail.com לקבל תפקידים.
|
name: organizations/ORG_ID/customConstraints/custom.dontGrantToGmail resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.exists( binding, binding.members.exists(member, MemberSubjectEndsWith(member, ['@gmail.com']) ) )" actionType: DENY displayName: Do not allow members whose email addresses end with "@gmail.com" to be granted roles |
| לאפשר רק לתפקידים ספציפיים להינתן, ורק לחשבונות משתמשים ספציפיים. |
name: organizations/ORG_ID/customConstraints/custom.allowSpecificRolesAndPrincipals resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.all( binding, RoleNameMatches(binding.role, ['ROLE_1', 'ROLE_2']) && binding.members.all(member, MemberSubjectMatches(member, ['serviceAccount:SERVICE_ACCOUNT', 'group:GROUP']) ) )" actionType: ALLOW displayName: Only allow ROLE_1 and ROLE_2 to be granted to SERVICE_ACCOUNT and GROUP |
למנוע הקצאת תפקידים ב-Cloud Storage ל-allUsers ול-allAuthenticatedUsers.
|
name: organizations/ORG_ID/customConstraints/custom.denyStorageRolesForPrincipalAllUsers resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.exists( binding, RoleNameStartsWith(binding.role, ['roles/storage.']) && binding.members.exists(member, MemberSubjectMatches(member, ['allUsers', 'allAuthenticatedUsers']) ) )" actionType: DENY displayName: Do not allow storage roles to be granted to allUsers or allAuthenticatedUsers |
| למנוע הקצאת תפקידים לזהויות מחוץ לארגון. |
name: organizations/ORG_ID/customConstraints/custom.allowInternaldentitiesOnly resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.all( binding, binding.members.all(member, MemberInPrincipalSet(member, ['//cloudresourcemanager.googleapis.com/organizations/ORG_ID']) ) )" actionType: ALLOW displayName: Only allow organization members to be granted roles |
| אפשר לתת תפקידים רק לחשבונות שירות. |
name: organizations/ORG_ID/customConstraints/custom.allowServiceAccountsOnly resourceTypes: iam.googleapis.com/AllowPolicy methodTypes: - CREATE - UPDATE condition: "resource.bindings.all( binding, binding.members.all(member, MemberTypeMatches(member, ['iam.googleapis.com/ServiceAccount']) ) )" actionType: ALLOW displayName: Only allow service accounts to be granted roles |
| למנוע הסרה של סוכני שירות בניהול Google מקישורי תפקידים. |
name: organizations/ORG_ID/customConstraints/custom.denyRemovalOfGoogleManagedServiceAgents resource_types: iam.googleapis.com/AllowPolicy method_types: - REMOVE_GRANT condition: |- resource.bindings.all( binding, binding.members.all(member, MemberTypeMatches(member, ['iam.googleapis.com/ServiceAgent']) ) ) action_type: DENY display_name: Deny Removal Of Google-Managed Service Agents description: Restricts the removal of Google-managed service agents from role bindings. Please reach out to your organization admins for if you have any questions. |
מדיניות ארגון מותנית
אפשר להגדיר מדיניות ארגונית מותנית בהתאמה אישית באמצעות תגים.
לדוגמה, נניח שכתבתם את האילוץ המותאם אישית הבא כדי למנוע הקצאה של תפקידים שמתחילים ב-roles/storage.:
name: organizations/ORG_ID/customConstraints/custom.dontgrantStorageRoles
resourceTypes: iam.googleapis.com/AllowPolicy
methodTypes:
- CREATE
- UPDATE
condition:
"resource.bindings.exists(
binding,
RoleNameStartsWith(binding.role, ['roles/storage.'])
)"
actionType: DENY
displayName: Prevent roles that start with "roles/storage." from being granted
כדי לאכוף את האילוץ באופן מותנה, אפשר ליצור מדיניות ארגונית כמו זו שבהמשך:
name: organizations/ORG_ID/policies/custom.dontgrantStorageRoles
spec:
rules:
- condition:
expression: "resource.matchTag('ORG_ID/environment', 'dev')"
enforce: true
- enforce: false
מדיניות הארגון הזו מונעת מתן תפקידים שמתחילים ב-roles/storage. בכל משאב שיש לו גם את התג environment=dev.
משאבים נתמכים בניהול זהויות והרשאות גישה
IAM תומך במשאב AllowPolicy. למשאב הזה יש מאפיין resources.bindings, שמוחזר לכל השיטות שמשנות את מדיניות ההרשאות של המשאב. כל ה-methods שמשנים את מדיניות ההרשאות של משאב מסתיימים ב-setIamPolicy.
למאפיין resource.bindings יש את המבנה הבא, כאשר BINDINGS הוא מערך של קישורי תפקידים ששונו במהלך שינוי במדיניות ההרשאה:
{
"bindings": {
BINDINGS
}
}
לכל קישור ב-resource.bindings יש את המבנה הבא, כאשר ROLE הוא שם התפקיד בקישור התפקידים ו-MEMBERS היא רשימה של מזהים של כל חשבונות המשתמשים שנוספו לקישור התפקידים או הוסרו ממנו:
{
"role": "ROLE"
"members": {
MEMBERS
}
}
כדי לראות את הפורמטים האפשריים של מזהי חשבונות משתמשים, אפשר לעיין במאמר מזהים של חשבונות משתמשים.
אפשר להעריך את מאפיין resource.bindings והשדות שלו רק באמצעות הפונקציות הנתמכות. אין תמיכה באופרטורים ובפונקציות אחרים, כמו ==, !=, in, contains, startsWith ו-endsWith.
פונקציות נתמכות
אפשר להשתמש בפונקציות CEL הבאות כדי להעריך תפקידים וחברים ספציפיים בהתאמה.
כדי להעריך את כל הקישורים במערך bindings או את כל החברים במערך members, משתמשים בפקודות המאקרו all ו-exists. מידע נוסף זמין בקטע פקודות מאקרו להערכת רשימות שבדף הזה.
אפשר גם להשתמש באופרטורים הלוגיים && (and) ו-|| (or) כדי לכתוב תנאים מרובי חלקים.
| תפקיד | תיאור |
|---|---|
RoleNameMatches(
bool
|
הפונקציה מחזירה
|
RoleNameStartsWith(
bool
|
הפונקציה מחזירה את הערך
|
RoleNameEndsWith(
bool
|
הפונקציה מחזירה את הערך
|
RoleNameContains(
bool
|
הפונקציה מחזירה
|
MemberSubjectMatches(
bool
|
הפונקציה מחזירה
אם המזהה של
|
MemberSubjectStartsWith(
bool
|
הפונקציה מחזירה
אם המזהה של
|
MemberSubjectEndsWith(
bool
|
הפונקציה מחזירה את הערך
אם המזהה של
|
MemberInPrincipalSet(
bool
|
הפונקציה מחזירה
|
MemberTypeMatches(
bool
|
הפונקציה מחזירה את הערך
|
פקודות מאקרו להערכת רשימות
משתמשים בפקודות המאקרו all ו-exists כדי להעריך ביטוי תנאי עבור רשימת פריטים.
| מאקרו | תיאור |
|---|---|
list.all(
bool
|
הפונקציה מחזירה
בדרך כלל משתמשים בפקודת המאקרו הזו בכללי מדיניות מותאמים אישית של הארגון עם
|
list.exists(
bool
|
הפונקציה מחזירה
בדרך כלל משתמשים בפקודת המאקרו הזו בכללי מדיניות מותאמים אישית של הארגון עם
|
תנאים עם רשימות מקוננות
באופן כללי, אם התנאי כולל רשימות מקוננות, צריך להשתמש באותה פקודת מאקרו לכל הרשימות בתנאי.
מומלץ להביא בחשבון את הדוגמאות הבאות:
- אם במדיניות שלכם מופיע
actionTypeALLOW, צריך להשתמש בפקודת המאקרוallגם ברשימהmembersוגם ברשימהbindingsכדי לוודא ששינויים במדיניות מותרים רק אם כל החברים בכל הקישורים ששונו עומדים בתנאי. - אם במדיניות שלכם יש את
actionTypeDENY, צריך להשתמש בפקודת המאקרוexistsגם ברשימהmembersוגם ברשימהbindingsכדי לוודא ששינויים במדיניות לא יתאפשרו אם חבר כלשהו בהתאמה ששונתה עומד בתנאי.
שילוב פקודות מאקרו בתנאי אחד עלול לגרום לתנאי שלא יתנהג כמו שרציתם.
לדוגמה, נניח שרוצים למנוע הקצאת תפקידים לחברים מחוץ לארגון example.com. לארגון example.com יש את המזהה 123456789012.
כדי להשיג את המטרה הזו, כותבים את התנאי הבא:
לא מומלץ – תנאי שהוגדר בצורה שגויה
"resource.bindings.all(
binding,
binding.members.exists(member,
MemberInPrincipalSet(member, ['//cloudresourcemanager.googleapis.com/organizations/123456789012'])
)
)"
נראה שהתנאי הזה מונע הקצאת תפקידים לחברים מחוץ לארגון example.com. עם זאת, התנאי יחזיר את הערך true אם כל חבר בכל אחד מהקשרים ששונתנו לתפקידים נמצא בארגון example.com. לכן, אתם עדיין יכולים להעניק תפקידים לחברים מחוץ לארגון example.com אם אתם מעניקים את אותו תפקיד גם לחבר בארגון example.com.
לדוגמה, התנאי מחזיר את הערך true עבור קבוצת הקישורים הבאה, למרות שאחד מהחברים לא שייך לארגון example.com:
"bindings": [ { "members": [ "user:raha@altostrat.com", "user:jie@example.com" ], "role": "roles/resourcemanager.projectCreator" } ],
במקום זאת, צריך לכתוב תנאי כמו זה:
מומלץ – תנאי שהוגדר בצורה נכונה
"resource.bindings.all(
binding,
binding.members.all(member,
MemberInPrincipalSet(member, ['//cloudresourcemanager.googleapis.com/organizations/123456789012'])
)
)"
שימוש בפקודת המאקרו all גם למערך members.bindings וגם למערך resource.bindings מבטיח שהתנאי יחזיר את הערך true רק אם כל החברים בכל ההתאמות נמצאים בקבוצת המשתמשים example.com.
סוגי חשבונות משתמש נתמכים עבור MemberTypeMatches
בפונקציה MemberTypeMatches צריך לציין את סוג החשבון שהמשתמש שצוין צריך להיות שייך אליו.
בטבלה הבאה מפורטים סוגי חשבונות המשתמשים שאפשר להזין, ותיאור של מה שכל סוג מייצג. בנוסף, מפורטים בה המזהים של החשבונות הראשיים שמתאימים לכל סוג של חשבון ראשי. המזהים האלה הם הערכים שמשמשים במדיניות IAM.
| סוג חשבון המשתמש | תיאור | מזהים של חשבונות משתמשים |
|---|---|---|
iam.googleapis.com/ |
חשבון פרטי ב-Google. כתובות האימייל של החשבונות האלה בדרך כלל מסתיימות ב-gmail.com.
|
user:USER_EMAIL_ADDRESS |
iam.googleapis.com/ |
חשבון Google שמשויך לחשבון Cloud Identity או לחשבון Google Workspace. החשבונות האלה נקראים גם חשבונות משתמשים מנוהלים. | user:USER_EMAIL_ADDRESS |
iam.googleapis.com/ |
קבוצת Google שנוצרה באמצעות חשבון Google פרטי. הקבוצות האלה לא בבעלות של חשבון Cloud Identity או Google Workspace. כתובות האימייל של הקבוצות האלה בדרך כלל מסתיימות ב-googlegroups.com.
|
group:GROUP_EMAIL_ADDRESS |
iam.googleapis.com/ |
קבוצה ב-Google שבבעלות חשבון Cloud Identity או Google Workspace. | group:GROUP_EMAIL_ADDRESS |
iam.googleapis.com/ |
חשבון Cloud Identity או Google Workspace. | domain:DOMAIN |
iam.googleapis.com/ |
חשבון משתמש יחיד במאגר זהויות של כוח עבודה. | principal://iam.googleapis.com/ |
iam.googleapis.com/ |
קבוצת ישויות (principal) שמכילה קבוצה של זהויות במאגר זהויות של כוח עבודה. לדוגמה, קבוצת נציגים שמכילה את כל הנציגים במאגר זהויות של כוח עבודה. |
|
iam.googleapis.com/ |
זהות יחידה במאגר זהויות של עומסי עבודה | principal://iam.googleapis.com/projects/ |
iam.googleapis.com/ |
קבוצת ישויות (principal) שמכילה קבוצה של זהויות במאגר זהויות של עומסי עבודה. לדוגמה, קבוצת ישויות מורשות שמכילה את כל הישויות המורשות במאגר זהויות של עומסי עבודה. |
|
iam.googleapis.com/ |
כל חשבון שירות. חשבון שירות הוא סוג מיוחד של חשבון שמייצג עומס עבודה ולא משתמש אנושי.
במסגרת הפונקציה |
serviceAccount:SERVICE_ACCOUNT_EMAIL_ADDRESS |
iam.googleapis.com/ |
כל סוכן שירות. סוכן שירות הוא סוג מיוחד של חשבון שירות ש- Google Cloud יוצר ומנהל. כשמעניקים תפקידים בפרויקטים לסוכני שירות, שירותי Google Cloud יכולים לבצע פעולות בשמכם. | serviceAccount:SERVICE_AGENT_EMAIL_ADDRESS |
iam.googleapis.com/ |
חשבונות המשתמשים allUsers ו-allAuthenticatedUsers.
|
|
iam.googleapis.com/ |
חשבונות משתמשים שמוגדרים על סמך התפקיד שהוקצה להם. הערכים האלה נקראים גם ערכי נוחות. |
|
iam.googleapis.com/ |
משאב עם זהות מובנית. | אחד ממזהי חשבון המשתמש שמפורטים במאמר מזהים של חשבונות משתמשים למשאבים בודדים. |
iam.googleapis.com/ |
משאבים עם זהויות מובנות שחולקים מאפיינים מסוימים, כמו סוג או ישות אב. | אחד מהמזהים שמפורטים במאמר מזהים של חשבונות משתמשים עבור קבוצות של משאבים. |
iam.googleapis.com/AgentIdentity |
זהות נציג אחת. |
|
iam.googleapis.com/AgentIdentitySet |
קבוצת חשבונות שכוללת קבוצה של זהויות של סוכנים. |
לדוגמה: |
המאמרים הבאים
- מידע נוסף על השירות של מדיניות הארגון
- מידע נוסף על יצירה וניהול של מדיניות הארגון
- כאן אפשר לראות את הרשימה המלאה של האילוצים המנוהלים של מדיניות הארגון.