Google User Messaging Platform (UMP) SDK הוא כלי לניהול פרטיות והודעות שיעזור לכם לנהל את העדפות הפרטיות של המשתמשים. מידע נוסף זמין במאמר בנושא הכלי 'פרטיות והודעות'.
יצירת סוג הודעה
יוצרים הודעות למשתמשים באמצעות אחד מסוגי ההודעות למשתמשים שזמינים בכרטיסייה פרטיות והודעות בחשבון AdMob. UMP SDK מנסה להציג הודעה בנושא פרטיות שנוצרה ממזהה האפליקציה ב-AdMob שהוגדר בפרויקט.
פרטים נוספים זמינים במאמר מידע על הכלי 'פרטיות והודעות'.
קבלת מידע על הסכמת המשתמש
צריך לבקש עדכון של פרטי ההסכמה של המשתמש בכל הפעלה של האפליקציה באמצעות requestConsentInfoUpdate()
. הבקשה הזו בודקת את הדברים הבאים:
- האם נדרשת הסכמה. לדוגמה, נדרשת הסכמה בפעם הראשונה, או שההחלטה הקודמת לגבי הסכמה פגה.
- האם נדרשת נקודת כניסה לאפשרויות הפרטיות. חלק מההודעות בנושא פרטיות מחייבות את האפליקציות לאפשר למשתמשים לשנות את אפשרויות הפרטיות שלהם בכל שלב.
@override
void initState() {
super.initState();
// Create a ConsentRequestParameters object.
final params = ConsentRequestParameters();
// Request an update to consent information on every app launch.
ConsentInformation.instance.requestConsentInfoUpdate(
params,
() async {
// Called when consent information is successfully updated.
},
(FormError error) {
// Called when there's an error updating consent information.
},
);
}
טעינה והצגה של טופס הודעת הפרטיות
אחרי שמתקבל מצב ההסכמה העדכני ביותר, צריך להתקשר אל
loadAndShowConsentFormIfRequired()
כדי לטעון את הטפסים שנדרשים לאיסוף הסכמה מהמשתמשים. אחרי הטעינה, הטפסים מוצגים מיד.
@override
void initState() {
super.initState();
// Create a ConsentRequestParameters object.
final params = ConsentRequestParameters();
// Request an update to consent information on every app launch.
ConsentInformation.instance.requestConsentInfoUpdate(
params,
() async {
ConsentForm.loadAndShowConsentFormIfRequired((loadAndShowError) {
if (loadAndShowError != null) {
// Consent gathering failed.
}
// Consent has been gathered.
});
},
(FormError error) {
// Handle the error.
},
);
}
אפשרויות פרטיות
חלק מהטפסים של ההודעות בנושא פרטיות מוצגים מנקודת כניסה לאפשרויות הפרטיות שמוצגת על ידי בעל התוכן הדיגיטלי, ומאפשרים למשתמשים לנהל את אפשרויות הפרטיות שלהם בכל שלב. מידע נוסף על ההודעה שתוצג למשתמשים בנקודת הכניסה לאפשרויות הפרטיות זמין במאמר הסוגים הזמינים של הודעות למשתמשים.
איך בודקים אם נדרשת נקודת כניסה לאפשרויות הפרטיות
אחרי שקוראים ל-requestConsentInfoUpdate()
, בודקים את getPrivacyOptionsRequirementStatus()
כדי לדעת אם נדרשת נקודת כניסה לאפשרויות הפרטיות באפליקציה. אם נדרשת נקודת כניסה, מוסיפים לאפליקציה רכיב גלוי בממשק המשתמש שאפשר לקיים איתו אינטראקציה, ושדרכו אפשר להציג את טופס אפשרויות הפרטיות. אם לא נדרשת נקודת כניסה להגדרות הפרטיות, צריך להגדיר את רכיב ממשק המשתמש כך שלא יהיה גלוי ואי אפשר יהיה לקיים איתו אינטראקציה.
/// Helper variable to determine if the privacy options entry point is required.
Future<bool> isPrivacyOptionsRequired() async {
return await ConsentInformation.instance
.getPrivacyOptionsRequirementStatus() ==
PrivacyOptionsRequirementStatus.required;
}
רשימה מלאה של סטטוסי הדרישות של אפשרויות הפרטיות מופיעה במאמר
.PrivacyOptionsRequirementStatus
הצגת טופס אפשרויות הפרטיות
כשמזוהה אינטראקציה של המשתמש עם הרכיב, מציגים את טופס אפשרויות הפרטיות:
ConsentForm.showPrivacyOptionsForm((formError) {
if (formError != null) {
debugPrint("${formError.errorCode}: ${formError.message}");
}
});
בקשת מודעות עם הסכמת משתמשים
לפני ששולחים בקשות להצגת מודעות, משתמשים ב-canRequestAds()
כדי לבדוק אם קיבלתם הסכמה מהמשתמש:
await ConsentInformation.instance.canRequestAds()
אלה המקומות שבהם אפשר לבדוק אם אפשר לבקש הצגת מודעות בזמן איסוף הסכמה:
- אחרי ש-UMP SDK אוסף הסכמה בסשן הנוכחי.
- מיד אחרי שמתקשרים אל
requestConsentInfoUpdate()
. יכול להיות ש-UMP SDK קיבל הסכמה בסשן הקודם באפליקציה.
אם מתרחשת שגיאה במהלך תהליך איסוף ההסכמה, צריך לבדוק אם אפשר לשלוח בקשות להצגת מודעות. UMP SDK משתמש בסטטוס ההסכמה מהסשן הקודם באפליקציה.
מניעת עבודה מיותרת על בקשות למודעות
כשבודקים את canRequestAds()
אחרי איסוף ההסכמה ואחרי הקריאה ל-requestConsentInfoUpdate()
, חשוב לוודא שהלוגיקה מונעת בקשות מיותרות להצגת מודעות, שעלולות לגרום לכך ששתי הבדיקות יחזירו את הערך true
. לדוגמה, עם משתנה בוליאני.
בדיקה
אם אתם רוצים לבדוק את השילוב באפליקציה במהלך הפיתוח, אתם יכולים לבצע את השלבים הבאים כדי לרשום את מכשיר הבדיקה באופן אוטומטי. חשוב להסיר את הקוד שמגדיר את מזהי מכשירי הבדיקה האלה לפני שמשחררים את האפליקציה.
- התקשרו אל
requestConsentInfoUpdate()
. בודקים את פלט היומן ומחפשים הודעה שדומה לדוגמה הבאה, שבה מוצג מזהה המכשיר והסבר איך להוסיף אותו כמכשיר בדיקה:
Android
Use new ConsentDebugSettings.Builder().addTestDeviceHashedId("33BE2250B43518CCDA7DE426D04EE231") to set this as a debug device.
iOS
<UMP SDK>To enable debug mode for this device, set: UMPDebugSettings.testDeviceIdentifiers = @[2077ef9a63d2b398840261c8221a0c9b]
מעתיקים את מזהה מכשיר הבדיקה ללוח.
משנים את הקוד כדי לקרוא ל-
ConsentDebugSettings.testIdentifiers
ולהעביר רשימה של מזהי מכשירי הבדיקה.ConsentDebugSettings debugSettings = ConsentDebugSettings( testIdentifiers: ["TEST-DEVICE-HASHED-ID"], ); ConsentRequestParameters params = ConsentRequestParameters(consentDebugSettings: debugSettings); ConsentInformation.instance.requestConsentInfoUpdate(params, () async { // ... };
אילוץ של מיקום גיאוגרפי
באמצעות UMP SDK אפשר לבדוק את אופן הפעולה של האפליקציה במקרה שבו המכשיר נמצא באזורים שונים, כמו האזור הכלכלי האירופי או בריטניה, באמצעות debugGeography
. הערה: הגדרות ניפוי הבאגים פועלות רק במכשירי בדיקה.
ConsentDebugSettings debugSettings = ConsentDebugSettings(
debugGeography: DebugGeography.debugGeographyEea,
testIdentifiers: ["TEST-DEVICE-HASHED-ID"],
);
ConsentRequestParameters params =
ConsentRequestParameters(consentDebugSettings: debugSettings);
ConsentInformation.instance.requestConsentInfoUpdate(params, () async {
// ...
};
איפוס מצב ההסכמה
כשבודקים את האפליקציה באמצעות ה-UMP SDK, יכול להיות שיהיה שימושי לאפס את מצב ה-SDK כדי לדמות את חוויית ההתקנה הראשונית של המשתמש.
ה-SDK מספק את ה-method reset()
כדי לעשות את זה.
ConsentInformation.instance.reset();
דוגמאות ב-GitHub
דוגמה מלאה לשילוב של UMP SDK שמוסבר בדף הזה מופיעה בדוגמאות ל-Flutter.