This page applies to Apigee and Apigee hybrid.
View Apigee Edge documentation.
Overview
The MonetizationLimitsCheck policy enables you to enforce monetization limits.
Specifically, the policy is triggered if the app developer accessing the monetized API has not purchased a subscription to the associated API product or if the developer has insufficient balance. In this case, The MonetizationLimitsCheck policy will raise a fault and block an API call. For more information, see Enforcing developer subscriptions to API products.
When you attach the MonetizationLimitsCheck policy to an API proxy, the mint.limitscheck.*
and mint.subscription_*
flow variables are populated, as described in the mint flow variable reference.
This policy is an Extensible policy and use of this policy might have cost or utilization implications, depending on your Apigee license. For information on policy types and usage implications, see Policy types.
<MonetizationLimitsCheck>
Defines the MonetizationLimitsCheck policy.
Default Value | N/A |
Required? | Required |
Type | Complex type |
Parent Element | N/A |
Child Elements |
<DisplayName> <FaultResponse> <IgnoreUnresolvedVariables> |
The following table provides a high-level description of the child elements of <MonetizationLimitsCheck>
:
Child Element | Required? | Description |
---|---|---|
<DisplayName> |
Optional | A custom name for the policy. |
<FaultResponse> |
Optional | Defines the response message returned to the requesting client. |
<IgnoreUnresolvedVariables> |
Optional | Ignores any unresolved variable error in the flow. |
The <MonetizationLimitsCheck>
element uses the following syntax:
Syntax
<?xml version="1.0" encoding="UTF-8" standalone="no"?><MonetizationLimitsCheck continueOnError="[true|false]" enabled="[true|false]" name="policy_name"> <DisplayName>POLICY_DISPLAY_NAME</DisplayName> <FaultResponse> <AssignVariable> <Name/> <Value/> </AssignVariable> <Add> <Headers/> </Add> <Copy source="request"> <Headers/> <StatusCode/> </Copy> <Remove> <Headers/> </Remove> <Set> <Headers/> <Payload/> <StatusCode/> </Set> </FaultResponse> <IgnoreUnresolvedVariables>VALUE</IgnoreUnresolvedVariables> </MonetizationLimitsCheck>
Example
In the following example, if a developer has not purchased subscription to the
associated API product, access to the monetized API is blocked, and a
403
status is returned with a custom message.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <MonetizationLimitsCheck continueOnError="false" enabled="true" name="MonetizationLimitsCheck-1"> <DisplayName>Monetization-Limits-Check-1</DisplayName> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <FaultResponse> <Set> <Payload contentType="text/xml"> <error> <messages> <message>Usage has been exceeded ({mint.limitscheck.isRequestBlocked}) or app developer has been suspended</message> </messages> </error> </Payload> <StatusCode>403</StatusCode> </Set> </FaultResponse> </MonetizationLimitsCheck>
This element has the following attributes that are common to all policies:
Attribute | Default | Required? | Description |
---|---|---|---|
name |
N/A | Required |
The internal name of the policy. The value of the Optionally, use the |
continueOnError |
false | Optional | Set to false to return an error when a policy fails. This is expected behavior for
most policies. Set to true to have flow execution continue even after a policy
fails. See also:
|
enabled |
true | Optional | Set to true to enforce the policy. Set to false to turn off the
policy. The policy will not be enforced even if it remains attached to a flow. |
async |
false | Deprecated | This attribute is deprecated. |
Child element reference
This section describes the child elements of<MonetizationLimitsCheck>
.
<DisplayName>
Use in addition to the name
attribute to label the policy in the
management UI proxy editor with a different, more natural-sounding name.
The <DisplayName>
element is common to all policies.
Default Value | N/A |
Required? | Optional. If you omit <DisplayName> , the value of the
policy's name attribute is used. |
Type | String |
Parent Element | <PolicyElement> |
Child Elements | None |
The <DisplayName>
element uses the following syntax:
Syntax
<PolicyElement> <DisplayName>POLICY_DISPLAY_NAME</DisplayName> ... </PolicyElement>
Example
<PolicyElement> <DisplayName>My Validation Policy</DisplayName> </PolicyElement>
The <DisplayName>
element has no attributes or child elements.
<FaultResponse>
Defines the response message returned to the requesting client. FaultResponse uses
the same settings as the <FaultResponse
>
element in the RaiseFault policy.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<MonetizationLimitsCheck> |
Child Elements |
<AssignVariable> <Add> <Copy> <Remove> <Set> |
<AssignVariable>
Assigns a value to a destination flow variable.
If the flow variable does not exist, then AssignVariable
creates it.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<FaultResponse> |
Child Elements |
<Name> <Value> |
For example, use the following code to set the variable named myFaultVar
in the MonetizationLimitsCheck policy:
<FaultResponse> <AssignVariable> <Name>myFaultVar</Name> <Value>42</Value> </AssignVariable> </FaultResponse>
A policy in a fault rule can then access the variable. For example, the following AssignMessage policy uses the variable to set a Header in the fault response:
<AssignMessage enabled="true" name="Assign-Message-1"> <Add> <Headers> <Header name="newvar">{myFaultVar}</Header> </Headers> </Add> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="response"/> </AssignMessage>
<AssignVariable>
in the MonetizationLimitsCheck policy uses the same syntax as the
<AssignVariable>
element in the AssignMessage policy.
<Name>
Variable name. For more information, see the Name element in the AssignMessage policy.
Default Value | N/A |
Required? | Optional |
Type | String |
Parent Element |
<AssignVariable> |
Child Elements | None |
<Value>
Variable value. For more information, see the Value element in the AssignMessage policy.
Default Value | N/A |
Required? | Optional |
Type | String |
Parent Element |
<AssignVariable> |
Child Elements | None |
<Add>
Adds HTTP headers to the error message.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<FaultResponse> |
Child Elements |
<Headers> |
<Headers>
Specifies the HTTP header to add, set, copy, or remove.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<Add> <Copy> <Remove> <Set> |
Child Elements | None |
Examples:
Add header
The following example copies the value of the request.user.agent
flow variable
into the header:
<Add> <Headers> <Header name="user-agent">{request.user.agent}</Header> </Headers> </Add>
Set header
The following example sets
the user-agent
header to the message variable specified with the
<AssignTo>
element.
<Set> <Headers> <Header name="user-agent">{request.header.user-agent}</Header> </Headers> </Set>
Copy header - 1
The following example copies the headerA
from the request:
<Copy source='request'> <Headers> <Header name="headerA"/> </Headers> </Copy>
Copy header - 2
The following example copies multiple headers:
<Copy source='request'> <Headers> <Header name="h1"/> <Header name="h2"/> <Header name="h3.2"/> </Headers> </Copy>
This example copies "h1", "h2", and the second value of "h3". If "h3" has only one value, then "h3" is not copied.
Remove header - 1
The following example removes a header:
<Remove> <Headers> <Header name="user-agent"/> </Headers> </Remove>
Remove header - 2
The following example removes multiple headers:
<Remove> <Headers> <Header name="h1"/> <Header name="h2"/> <Header name="h3.2"/> </Headers> </Remove>
This example removes "h1", "h2", and the second value of "h3". If "h3" has only one value, then "h3" is not removed.
<Copy>
Copies information from the message specified by the
source
attribute to the error message.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<FaultResponse> |
Child Elements |
<Headers> <StatusCode> |
The following table describes the attributes of <Copy>
:
Attribute | Required? | Type | Description |
---|---|---|---|
source | Optional | String |
Specifies the source object of the copy.
|
<StatusCode>
Specifies the HTTP status code in the error message. You can copy or set the value from
for the object specified by the source
attribute.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<Copy> <Set> |
Child Elements | None |
Example:
Copy status code
<Copy source='response'> <StatusCode>404</StatusCode> </Copy>
Set status code
<Set source='request'> <StatusCode>404</StatusCode> </Set>
<Remove>
Removes specified HTTP headers from the error message. To remove all the headers, specify
<Remove><Headers/></Remove>
.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<FaultResponse> |
Child Elements |
<Headers> |
<Set>
Sets information in the error message.
Default Value | N/A |
Required? | Optional |
Type | Complex type |
Parent Element |
<FaultResponse> |
Child Elements |
<Headers> <Payload> <StatusCode> |
<Payload>
Sets the payload of the error message.
Default Value | N/A |
Required? | Optional |
Type | String |
Parent Element |
<Set> |
Child Elements | None |
Examples:
Set text payload
<Set> <Payload contentType="text/plain">test1234</Payload> </Set>
Set JSON payload - 1
<Set> <Payload contentType="application/json"> {"name":"foo", "type":"bar"} </Payload> </Set>
Set JSON payload - 2
<Set> <Payload contentType="application/json" variablePrefix="@" variableSuffix="#"> {"name":"foo", "type":"@variable_name#"} </Payload> </Set>
This example inserts variables using the variablePrefix
and
variableSuffix
attributes with delimiter characters.
Set JSON payload - 3
<Set> <Payload contentType="application/json"> {"name":"foo", "type":"{variable_name}"} </Payload> </Set>
This example inserts variables using curly braces. You can use curly braces starting with the 16.08.17 release.
Set XML payload
<Set> <Payload contentType="text/xml"> <root> <e1>sunday</e1> <e2>funday</e2> <e3>{var1}</e3> </Payload> </Set>
This example inserts variables using curly braces. You can use curly braces starting with the 16.08.17 release.
<IgnoreUnresolvedVariables>
Determines whether processing stops when an unresolved variable is encountered.
Set to true
to ignore unresolved variables and continue processing; otherwise false
. The
default value is true
.
Setting <IgnoreUnresolvedVariables>
to true
is different from setting the <MonetizationLimitsCheck>
's
continueOnError
to true
. If you set continueOnError
to true
, Apigee ignores all errors, not
only errors in variables.
The <IgnoreUnresolvedVariables>
element uses the following syntax:
Syntax
<IgnoreUnresolvedVariables>[true|false]</IgnoreUnresolvedVariables>
Example
The following example sets <IgnoreUnresolvedVariables>
to false
:
<IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables>
Error codes
This section describes the fault codes and error messages that are returned and fault variables that are set by Apigee when this policy triggers an error. This information is important to know if you are developing fault rules to handle faults. To learn more, see What you need to know about policy errors and Handling faults.
Runtime errors
These errors can occur when the policy executes.
Fault code | HTTP status | Cause |
---|---|---|
mint.service.subscription_not_found_for_developer |
500 |
This error occurs when a developer does not have a subscription to the API Product. |
mint.service.wallet_not_found_for_developer |
500 |
This error occurs when a prepaid developer attempts to consume a monetized API without maintaining a wallet for the currency specified in rate plan. |
mint.service.developer_usage_exceeds_balance |
500 |
This error occurs when a prepaid developer's usage exceeds the wallet balance. |
mint.service.wallet_blocked_due_to_inactivity |
500 |
This error occurs when a prepaid developer's wallet is not topped up in over 1.5 years and the developer attempts to consume an API. |
Fault variables
Whenever there are execution errors in a policy, Apigee generates error messages. You can view these error messages in the error response. Many a time, system generated error messages might not be relevant in the context of your product. You might want to customize the error messages based on the type of error to make the messages more meaningful.
To customize the error messages, you can use either fault rules or the RaiseFault policy. For
information about differences between fault rules and the RaiseFault policy, see
FaultRules vs. the RaiseFault policy.
You must check for conditions using the Condition
element in both the fault rules and the RaiseFault policy.
Apigee provides fault variables unique to each policy and the values of the fault variables are set when a policy triggers runtime errors.
By using these variables, you can check for specific error conditions and take appropriate actions. For more information about checking error
conditions, see Building conditions.
Variables | Where | Example |
---|---|---|
fault.name |
The fault.name can match to any of the faults listed in the Runtime errors table.
The fault name is the last part of the fault code. |
fault.name Matches "UnresolvedVariable" |
MonetizationLimitsCheck.POLICY_NAME.failed |
POLICY_NAME is the user-specified name of the policy that threw the fault. | MonetizationLimitsCheck.monetization-limits-check-1.failed = true |
Flow variables
The following predefined flow variables automatically populate when the MonetizationLimitsCheck policy executes. For more information, see the mint flow variables.
Flow variable | Description |
---|---|
mint.limitscheck.is_request_blocked |
true for blocked requests. |
mint.limitscheck.is_subscription_found |
true if an API subscription is found. |
mint.limitscheck.purchased_product_name |
Name of the purchased API product. For example: MyProduct . |
mint.limitscheck.status_message |
Status message. For example: limits_check_success . |
mint.subscription_end_time_ms |
End time of the API product subscription. |
mint.subscription_start_time_ms |
Start time of the API product subscription. For example: 1618433956209 . |