שיטה: פענוח מפתח פרטי

פתיחת אריזה של מפתח פרטי ארוז, ולאחר מכן פענוח של מפתח הצפנת התוכן שמצפין את המפתח הציבורי.

בקשת HTTP

POST https://BASE_URL/privatekeydecrypt

מחליפים את BASE_URL בכתובת ה-URL הבסיסית.

פרמטרים של נתיב

ללא.

גוף הבקשה

גוף הבקשה מכיל נתונים במבנה הבא:

ייצוג ב-JSON
{
  "authentication": string,
  "authorization": string,
  "algorithm": string,
  "encrypted_data_encryption_key": string,
  "rsa_oaep_label": string,
  "reason": string,
  "wrapped_private_key": string
}
שדות
authentication

string

JWT שהונפקה על ידי ספק הזהויות (IdP) ומצהירה על זהות המשתמש. ראו אסימוני אימות.

authorization

string

JWT שמצהיר שהמשתמש מורשה לפתוח מפתח עבור resource_name. טוקני הרשאה

algorithm

string

האלגוריתם ששימש להצפנת המפתח להצפנת נתונים (DEK) בהצפנת מעטפת.

encrypted_data_encryption_key

string (UTF-8)

מפתח הצפנה של תוכן מוצפן בקידוד Base64, שמאובטח באמצעות המפתח הציבורי שמשויך למפתח הפרטי. גודל מקסימלי: 1KB.

rsa_oaep_label

string

תווית L בקידוד Base64, אם האלגוריתם הוא RSAES-OAEP. אם האלגוריתם הוא לא RSAES-OAEP, המערכת מתעלמת מהשדה הזה.

reason

string (UTF-8)

מחרוזת JSON לצורך העברה (passthrough) שמספקת הקשר נוסף לגבי הפעולה. צריך לנקות את ה-JSON שסופק לפני שהוא מוצג. גודל מקסימלי: 1KB.

wrapped_private_key

string

המפתח הפרטי המקודד ב-base64. גודל מקסימלי: 8KB.

הפורמט של המפתח הפרטי או של המפתח הפרטי המאו包 תלוי בהטמעה של שירות רשימת המפתחות של בקרת הגישה (KACLS). בצד הלקוח ובצד Gmail, הנתונים האלה מטופלים כ-blob אטום.

גוף התשובה

אם הפעולה בוצעה ללא שגיאות, השיטה מחזירה מפתח להצפנת נתונים ב-base64.

אם הפעולה נכשלת, מוחזר תגובה מובנית לשגיאה.

ייצוג ב-JSON
{
  "data_encryption_key": string
}
שדות
data_encryption_key

string

מפתח להצפנת נתונים בקידוד Base64.

דוגמה

בדוגמה הזו מוצגות בקשה ותגובה לדוגמה של השיטה privatekeydecrypt.

בקשה

POST https://mykacls.example.org/v1/privatekeydecrypt

{
  "wrapped_private_key": "wHrlNOTI9mU6PBdqiq7EQA...",
  "encrypted_data_encryption_key": "dGVzdCB3cmFwcGVkIGRlaw...",
  "authorization": "eyJhbGciOi...",
  "authentication": "eyJhbGciOi...",
  "algorithm": "RSA/ECB/PKCS1Padding",
  "reason": "decrypt"
}

תשובה

{
  "data_encryption_key": "akRQtv3nr+jUhcFL6JmKzB+WzUxbkkMyW5kQsqGUAFc="
}