בדף הזה מופיע מידע עזר ליצירת ביטויים של תנאים באמצעות ממשקי קצה עורפיים של Remote Config או מסוף Firebase. מידע נוסף על הגדרה ושימוש בממשקי ה-API של ה-Backend זמין במאמר שינוי הגדרת התצורה מרחוק באופן פרוגרמטי.
רכיבים שמשמשים ליצירת תנאים
Remote Config REST API תומך באותם רכיבים שאפשר להשתמש בהם כדי ליצור תנאים כשמגדירים את Remote Config באמצעות מסוף Firebase:
רכיב | תיאור |
---|---|
&& |
משמש ליצירת לוגיקת 'וגם' בין אלמנטים אם משתמשים ביותר מאלמנט אחד בתנאי. אם משתמשים ברכיב בתחביר REST בלי הערה: צריך להוסיף רווח לפני ואחרי סימני האמפרסנד. לדוגמה:
|
app.build |
הפונקציה מחזירה את הערך הערה: התכונה זמינה רק במכשירי Apple ו-Android. ב-Apple, משתמשים בערך של CFBundleVersion וב-Android, משתמשים בערך של versionCode. |
app.version |
הפונקציה מחזירה את הערך הערה: במכשירי Android משתמשים בערך של versionName, ובמכשירי Apple משתמשים בערך של CFBundleShortVersionString. |
app.id |
רכיב שמבוסס על מזהה האפליקציה ב-Firebase |
app.audiences |
רכיב שהערך שלו הוא TRUE או FALSE על סמך הנוכחות או היעדרות של המשתמש בקהל אחד או יותר ב-Firebase Analytics. |
app.firstOpenTimestamp |
רכיב שמבוסס על הפעם הראשונה שבה המשתמש מפעיל אפליקציה, ומתקבל מהאירוע Google Analytics first_open . הפורמט הוא תאריך ISO עם אפשרות לציין אזור זמן קבוע. לדוגמה, app.firstOpenTimestamp >= ('2022-10-31T14:37:47', 'America/Los_Angeles') .
אם לא מציינים אזור זמן, המערכת משתמשת ב-GMT.
|
app.userProperty |
רכיב שערך ההערכה שלו הוא TRUE או FALSE על סמך הערך המספרי או ערך המחרוזת של Google Analytics
מאפיין משתמש. |
app.operatingSystemAndVersion |
רכיב שמבוסס על מערכת ההפעלה שבה האפליקציה פועלת.
הערך שמתקבל הוא הערה: האפשרות הזו זמינה רק לאפליקציות אינטרנט. |
app.browserAndVersion |
רכיב שמבוסס על הדפדפן שבו האפליקציה פועלת.
הערך שמתקבל הוא הערה: האפשרות הזו זמינה רק לאפליקציות אינטרנט. |
app.firebaseInstallationId |
רכיב שמבוסס על המזהים של התקנות ספציפיות של מכשירים.
הערך שמתקבל הוא TRUE אם מזהה ההתקנה תואם לאחד ממזהי ההתקנה שצוינו. |
app.customSignal |
רכיב ששווה ל-TRUE או ל-FALSE על סמך הערך המספרי, הסמנטי או המחרוזתי של תנאי האותות המותאמים אישית. |
device.country |
רכיב שמבוסס על האזור או המדינה שבהם נמצא המכשיר, באמצעות תקן ISO 3166-1 alpha-2 (לדוגמה, US או UK). התוצאה היא
TRUE אם המדינה תואמת לקוד המדינה הצפוי. |
device.dateTime |
רכיב שמבוסס על הזמן של האחזור האחרון שהמכשיר מבצע.
משתמש בפורמט תאריך ISO עם האפשרות לציין אזור זמן קבוע, לדוגמה, dateTime('2017-03-22T13:39:44', 'America/Los_Angeles') . |
device.language |
רכיב שמבוסס על השפה שנבחרה במכשיר. השפה מיוצגת באמצעות תג שפה של IETF, כמו es-ES, pt-BR או en-US.
הפונקציה מחזירה את הערך TRUE אם השפה תואמת לקוד שפה צפוי. |
device.os |
רכיב שמבוסס על מערכת ההפעלה שמשמשת במכשיר (Apple או Android).
הערך שמתקבל הוא TRUE כשמערכת ההפעלה של המכשיר היא מהסוג הצפוי. |
percent |
הערך שמתקבל הוא TRUE על סמך הכללת משתמש באחוז חלקי שהוקצה באופן אקראי (עם גדלי מדגם קטנים כמו 0.000001%). |
תנאי של רכיב יחיד מכיל שלושה שדות:
name
(עד 100 תווים)- ביטוי מותנה שהערך המחושב שלו הוא
TRUE
אוFALSE
, שמורכב מהרכיבים שמוצגים למעלה. - (אופציונלי) הערך
tagColor
, שיכול להיותBLUE
,BROWN
,CYAN
,DEEP_ORANGE
,GREEN
,INDIGO
,LIME
,ORANGE
,PINK
,PURPLE
אוTEAL
. הצבע לא תלוי באותיות רישיות ומשפיע רק על האופן שבו התנאים מוצגים במסוף Firebase.
אופרטורים נתמכים
לדוגמה, הפונקציהapp.build.notContains([123, 456])
מחזירה TRUE
אם
הגרסה בפועל של האפליקציה היא 123 או 492, אבל מחזירה FALSE
אם הגרסה בפועל של האפליקציה היא 999.
לדוגמה,
הפונקציה app.version.notContains([123, 456])
מחזירה את הערך TRUE
אם
גרסת האפליקציה בפועל היא 123 או 492, אבל מחזירה את הערך FALSE
אם גרסת האפליקציה בפועל היא 999.
רכיב | אופרטורים נתמכים | תיאור |
---|---|---|
app.audiences |
.inAtLeastOne([...]) |
הפונקציה מחזירה את הערך app.audiences.inAtLeastOne(['Audience 1', 'Audience 2']) |
app.audiences |
.notInAtLeastOne([...]) |
הפונקציה מחזירה את הערך |
app.audiences |
.inAll([...]) |
הפונקציה מחזירה את הערך |
app.audiences |
.notInAll([...]) |
הפונקציה מחזירה |
app.firstOpenTimestamp |
<=, > |
משווה את הזמן של האירוע |
app.userProperty |
< , <= , == , != ,
>= , > |
הפונקציה מחזירה את הערך |
app.userProperty |
.contains([...]) |
הפונקציה מחזירה |
app.userProperty |
.notContains([...]) |
הפונקציה מחזירה |
app.userProperty |
.exactlyMatches([...]) |
הפונקציה מחזירה את הערך |
app.userProperty |
.matches([...]) |
הפונקציה מחזירה |
app.id |
== |
הפונקציה מחזירה את הערך |
app.build |
< , <= , == , != ,
>= , > |
הפונקציה מחזירה את הערך |
app.build |
.contains([...]) |
הפונקציה מחזירה את הערך |
app.build |
.notContains([...]) |
הפונקציה מחזירה את הערך |
app.build |
.exactlyMatches([...]) |
הפונקציה מחזירה את הערך |
app.build |
.matches([...]) |
הפונקציה מחזירה |
app.version |
< , <= , == , != ,
>= , > |
הפונקציה מחזירה את הערך |
app.version |
.contains([...]) |
הפונקציה מחזירה |
app.version |
.notContains([...]) |
הפונקציה מחזירה את הערך |
app.version |
.exactlyMatches([...]) |
הפונקציה מחזירה את הערך |
app.version |
.matches([...]) |
הפונקציה מחזירה |
app.operatingSystemAndVersion |
.inOne([...]) |
הפונקציה מחזירה את הערך app.operatingSystemAndVersion.inOne([operatingSystemName('Macintosh') .version.==('10.15')]) |
app.browserAndVersion |
.inOne([...]) |
הפונקציה מחזירה app.browserAndVersion.inOne([browserName('Chrome').anyVersion]) |
app.firebaseInstallationId |
in [...] |
הפונקציה מחזירה את הערך |
app.customSignal |
< , <= , == , != ,
>= , > |
הפונקציה מחזירה את הערך |
app.customSignal |
.contains([...]) |
הפונקציה מחזירה |
app.customSignal |
.notContains([...]) |
הפונקציה מחזירה |
app.customSignal |
.exactlyMatches([...]) |
הפונקציה מחזירה את הערך |
app.customSignal |
.matches([...]) |
הפונקציה מחזירה |
version(app.customSignal) |
< , <= , == , != ,
>= , > |
הפונקציה מחזירה את הערך |
device.country |
in [...] |
הפונקציה מחזירה |
device.dateTime |
<= , > |
הפונקציה משווה בין השעה הנוכחית לבין שעת היעד של התנאי, ומחזירה את הערך |
device.language |
in [...] |
הפונקציה מחזירה |
device.os |
== , != |
הפונקציה מחזירה TRUE אם מערכת ההפעלה של המכשיר תואמת לערך בשדה הזה בהתאם לאופרטור. |
percent |
<= , > , between |
הפונקציה מחזירה אפשר לציין ערך התחלתי כדי לבחור קבוצה חדשה של מופעי אפליקציה שהוקצו באופן אקראי לטווח אחוזים נתון, כמו שמתואר במאמר בנושא סוגים של כללי תנאים. כדי לעשות זאת, צריך לציין את שם המונח המרכזי לפני האופרטור, כמו בדוגמה הבאה: percent('keyName') <= 10 כדי להגדיר טווח ספציפי, אפשר להשתמש באופרטור percent between 20 and 60 כדי להגדיר טווח של משתמשים בין 60 ל-80 באמצעות seed בהתאמה אישית: percent('seedName') between 60 and 80 |