המדיניות בנושא MonetizeLimitsCheck

מוצג המסמך של Apigee Edge.
עוברים אל מסמכי תיעוד של Apigee X.
מידע

סקירה כללית

המדיניות MonetizeLimitsCheck מאפשרת לאכוף הגבלות מונטיזציה על קריאות ל-API שנשלחות מפַתח האפליקציה.

אלה כמה מהמקרים שבהם המדיניות מופעלת:

  • אם מפתח אפליקציות שניגש ל-API לייצר הכנסות לא רכש מינוי ל- מוצר ה-API המשויך
  • בחשבון של המפתח אין יתרה מספקת.
  • המפתח חרג ממגבלת נפח העסקאות.

למידע נוסף על צירוף המדיניות לשרת ה-proxy של ה-API, אפשר לעיין במאמר לאכוף מגבלות מונטיזציה בשרתי proxy ל-API.

רכיב <MonetizationLimitsCheck>

מציינת את המדיניות MonetizeLimitsCheck.

ערך ברירת מחדל לא רלוונטי
חובה? חובה
סוג סוג מורכב
רכיב הורה לא רלוונטי
רכיבים צאצאים <DisplayName>
<FaultResponse>
<IgnoreUnresolvedVariables>
<Variables>

בטבלה הבאה יש תיאור כללי של רכיבי הצאצא של <MonetizationLimitsCheck>:

רכיב צאצא חובה? תיאור
<DisplayName> אופציונלי שם מותאם אישית למדיניות.
<FaultResponse> אופציונלי המדיניות הזו מציינת את הודעת התשובה שמוחזרת ללקוח ששלח את הבקשה כאשר יש טעות.
<IgnoreUnresolvedVariables> אופציונלי המדיניות הזו קובעת אם העיבוד ייפסק כשנתקלים במשתנה שלא זוהה.
<Variables> אופציונלי מציינת את משתני הזרימה כדי לבדוק את מגבלות המונטיזציה.

הרכיב <MonetizationLimitsCheck> משתמש בתחביר הבא:

תחביר

<?xml version="1.0" encoding="UTF-8"?>
<MonetizationLimitsCheck async="false" continueOnError="false" enabled="true" name="POLICY_NAME">
    <DisplayName>DISPLAY_NAME</DisplayName>
    <IgnoreUnresolvedVariables>[true|false]</IgnoreUnresolvedVariables>
    <Variables>
        <Product>VARIABLE_NAME</Product>
    </Variables>
    <FaultResponse>
        <Set>
            <Payload contentType="text/xml">
                <error>
                    <messages>
                        <message>MESSAGE_TEXT</message>
                        <message>MESSAGE_TEXT</message>
                    </messages>
                </error>
            </Payload>
            <StatusCode>HTTP_STATUS</StatusCode>
            <ReasonPhrase>REASON_TEXT</ReasonPhrase>
        </Set>
    </FaultResponse>
</MonetizationLimitsCheck>

דוגמה

הדוגמה הבאה מציגה את הגדרת המדיניות MonetizationLimitsCheck:

<?xml version="1.0" encoding="UTF-8"?>
<MonetizationLimitsCheck async="false" continueOnError="false" enabled="true" name="Monetization-Limits-Check">
    <DisplayName>Monetization Limits Check</DisplayName>
    <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
    <Variables>
        <Product>myproductvar.name</Product>
    </Variables>
	<FaultResponse>
	        <Set>
	            <Payload contentType="text/xml">
	                <error>
	                    <messages>
	                        <message>Developer has reached usage quota</message>
	                        <message>Is Developer Suspended - {monetizationLimits.isDeveloperSuspended} </message>
	                    </messages>
	                </error>
	            </Payload>
	            <StatusCode>403</StatusCode>
	            <ReasonPhrase>Forbidden</ReasonPhrase>
	        </Set>
	</FaultResponse>
 </MonetizationLimitsCheck>

לרכיב הזה יש את המאפיינים הבאים, המשותפים לכל כללי המדיניות:

מאפיין ברירת מחדל חובה? תיאור
name לא רלוונטי נדרש

השם הפנימי של המדיניות. הערך של המאפיין name יכול להכיל אותיות, מספרים, רווחים, מקפים, קווים תחתונים ונקודות. האורך המקסימלי של הערך הוא 255 תווים.

אפשר להשתמש ברכיב <DisplayName> כדי להוסיף תווית למדיניות בכלי לעריכת שרת proxy של ממשק המשתמש לניהול, ולהשתמש בשם אחר בשפה טבעית.

continueOnError false אופציונלי צריך להגדיר את הערך 'False' כדי להחזיר שגיאה כשהמדיניות נכשלת. זו התנהגות צפויה ברוב סוגי המדיניות. הערך של הפרמטר הוא TRUE כדי שביצוע הפעולות יתבצע גם אחרי שמדיניות תיכשל.
enabled true אופציונלי כדי לאכוף את המדיניות צריך להגדיר את הערך True. מגדירים את המדיניות כ-"false" כדי "להשבית" את המדיניות. המדיניות הזו לא תיאכף גם אם היא תצורף לתהליך.
async   false הוצא משימוש המאפיין הזה הוצא משימוש.

הפניה לרכיב צאצא

בקטע הזה מתוארים רכיבי הצאצא של <MonetizationLimitsCheck>.

<DisplayName>

אפשר להשתמש במאפיין name כדי לתייג את המדיניות בכלי העריכה של שרת ה-proxy בממשק המשתמש לניהול, בשם שונה שנשמע טבעי יותר.

הרכיב <DisplayName> הוא משותף לכל כללי המדיניות.

ערך ברירת המחדל לא רלוונטי
חובה? זה שינוי אופציונלי. אם משמיטים את <DisplayName>, המערכת משתמשת בערך של המאפיין name במדיניות
סוג מחרוזת
רכיב הורה <PolicyElement>
רכיבי הצאצאים ללא

רכיב <DisplayName> כולל את התחביר הבא:

תחביר

<PolicyElement>
  <DisplayName>policy_display_name</DisplayName>
  ...
</PolicyElement>

דוגמה

<PolicyElement>
  <DisplayName>My Validation Policy</DisplayName>
</PolicyElement>

לאלמנט <DisplayName> אין מאפיינים או רכיבי צאצא.

<IgnoreUnresolvedVariables>

קובעת אם עיבוד המדיניות צריך להפסיק כש-Apigee נתקלת במשתנה לא מפוענח.

ערך ברירת מחדל נכון
חובה? אופציונלי
סוג ערך בוליאני
רכיב הורה <MonetizationLimitsCheck>
רכיבים צאצאים ללא

כדי להתעלם ממשתנים לא מפוענחים ולהמשיך בעיבוד, צריך להגדיר את הערך ל-true. אחרת, false. ערך ברירת המחדל הוא true.

הגדרת הערך של <IgnoreUnresolvedVariables> לערך true שונה מהגדרת הרכיב <MonetizationLimitsCheck> continueOnError אל true. אם מגדירים את continueOnError לערך true, מערכת Apigee תתעלם רק את השגיאות במשתנים, אבל את כל השגיאות.

הרכיב <IgnoreUnresolvedVariables> משתמש בתחביר הבא:

תחביר

<IgnoreUnresolvedVariables>[true|false]</IgnoreUnresolvedVariables>

דוגמה

הדוגמה הבאה מגדירה את <IgnoreUnresolvedVariables> כ-false:

<IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables>

<Variables>

מציינת את משתני הזרימה שמהם רוצים לאחזר את שמות של ישויות או משאבים במהלך הפעלת המדיניות.

ניתן לציין רק את הרכיב <Product> בתוך הרכיב <Variables>. Apigee מקבלת שם המוצר של ה-API ממשתנה הזרימה שצוין ברכיב <Product>. אם לא מציינים את הרכיב <Variables>, Apigee כברירת מחדל מקבלת את שם המוצר של API משתנה הקשר apiproduct.name. באמצעות שימוש בשם המוצר של API, Apigee מקבלת את תוכנית התמחור והתשלומים המתאימה למוצר ומבצעת את בדיקת ההגבלות על המונטיזציה.

ערך ברירת מחדל לא רלוונטי
חובה? אופציונלי
סוג סוג מורכב
רכיב הורה <MonetizationLimitsCheck>
רכיבים צאצאים <Product>

הרכיב <Variables> משתמש בתחביר הבא:

תחביר

<Variables>
    <Product>VARIABLE_NAME</Product>
</Variables>

דוגמה

הדוגמה הבאה מקבלת את שם המוצר ב-API ממשתנה הזרימה המותאם אישית myproductvar.name שקיימים בתהליך ה-Proxy ל-API.

<Variables>
    <Product>myproductvar.name</Product>
</Variables>

אתם יכולים להגדיר משתני זרימה מותאמים אישית באמצעות כללי מדיניות כמו AssignMessage או JavaScript.

<Product>

מציינת את המשתנה עם שם המוצר ב-API.

ערך ברירת מחדל לא רלוונטי
חובה? אופציונלי
סוג מחרוזת
רכיב הורה <Variables>
רכיבים צאצאים ללא

הרכיב <Product> משתמש בתחביר הבא:

תחביר

<Product>VARIABLE_NAME</Product>

דוגמה

הדוגמה הבאה מקבלת את שם המוצר ב-API ממשתנה הזרימה המותאם אישית myproductvar.name שקיימים בתהליך ה-Proxy ל-API.

<Product>myproductvar.name</Product>

אתם יכולים להגדיר משתני זרימה מותאמים אישית באמצעות כללי מדיניות כמו AssignMessage או JavaScript.

<FaultResponse>

הגדרת הודעת התשובה שמוחזרת ללקוח ששלח את הבקשה אם נמצאה טעות. אפשר להתאים אישית את התשובה בהתאם לדרישות שלכם. לקבלת מידע נוסף על וכל רכיבי הצאצא שלו, ראו FaultResponse.

משתני זרימה

אם מגדירים את הרכיב <MonetizationLimitsCheck> המאפיין ContinueOnError מוגדר ל-True, אין טעות. במקרה הזה, הפרמטר משתני זרימה, mint.limitsViolated, mint.isDeveloperSuspended, וגם mint.limitsPolicyError מוגדרים באופן אוטומטי. אפשר להשתמש במשתנים האלה כדי לבצע טיפול נוסף בחריגות לפי הצורך.