Esta página aplica-se ao Apigee e ao Apigee Hybrid.
Veja a documentação do
Apigee Edge.
Vista geral
A política AssertCondition avalia uma declaração condicional no tempo de execução nos fluxos de pedidos ou respostas. Pode definir uma condição com base nas variáveis do fluxo e usar esta política para afirmar a condição. Uma condição é sempre avaliada como um valor booleano, verdadeiro ou falso. Para mais informações sobre como escrever uma declaração condicional, consulte a Referência de condições.
Após a avaliação da condição, a política AssertCondition armazena o resultado da avaliação na variável de fluxo assertcondition.policy-name.truthValue.
Pode usar a variável de fluxo resultante nos seus pedidos de informações subsequentes ou na lógica orquestrada.
Se uma condição for avaliada como verdadeira, o valor da variável é definido como
true. Caso contrário, é false. Se tiver definido várias políticas de AssertCondition, o policy-name no nome da variável ajuda a identificar a variável de forma exclusiva.
Esta política é uma política padrão e pode ser implementada em qualquer tipo de ambiente. Para obter informações sobre os tipos de políticas e a disponibilidade com cada tipo de ambiente, consulte Tipos de políticas.
<AssertCondition>
Define uma política <AssertCondition>. Ao usar esta política, pode avaliar uma declaração condicional que tenha uma ou mais condições unidas por um operador lógico. Para ver informações
sobre todos os operadores suportados numa condição, consulte o artigo Operadores.
true ou false.
| Valor predefinido | N/A |
| Obrigatório? | Obrigatória |
| Tipo | Tipo complexo |
| Elemento principal | N/A |
| Elementos subordinados |
<Condition><DisplayName> |
A tabela seguinte apresenta uma descrição geral dos elementos subordinados de <AssertCondition>:
| Elemento secundário | Obrigatório? | Descrição |
|---|---|---|
<Condition> |
Sim | Especifica a condição a avaliar. |
<DisplayName> |
Opcional | Um nome personalizado para a política. |
O elemento <AssertCondition> usa a seguinte sintaxe:
Sintaxe
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssertCondition">
<!-- Display name for this policy -->
<DisplayName>DISPLAY_NAME</DisplayName>
<!-- Assertion's condition where operators are defined -->
<Condition>CONDITIONAL_STATEMENT</Condition>
</AssertCondition>Exemplo
O exemplo seguinte verifica se a variável google.dialogflow.my-prefix.claimAmount é superior a 0 e inferior a 1000.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssertCondition continueOnError="false" enabled="true"
name="MyAssertCondition">
<DisplayName>Assert My Condition</DisplayName>
<Condition>(google.dialogflow.my-prefix.claimAmount > 0)
and
(google.dialogflow.my-prefix.claimAmount LesserThan 1000)</Condition>
</AssertCondition>Neste exemplo:
- Se o valor da variável
google.dialogflow.my-prefix.claimAmountfor 500, a condição é avaliada como verdadeira e, por isso, a variávelassertcondition.MyAssertCondition.truthValueé definida comotrue. - No entanto, se o valor da variável
google.dialogflow.my-prefix.claimAmountfor 1200, a variávelassertcondition.MyAssertCondition.truthValueé definida comofalse.
Este elemento tem os seguintes atributos comuns a todas as políticas:
| Atributo | Padrão | Obrigatório? | Descrição |
|---|---|---|---|
name |
N/A | Valor |
O nome interno da política. O valor do atributo Opcionalmente, use o elemento |
continueOnError |
falso | Opcional | Defina como false para retornar um erro quando uma política falhar. Esse é o comportamento esperado para
a maioria das políticas. Defina como true para que a execução do fluxo continue, mesmo depois que uma política
falhar. Consulte também:
|
enabled |
true | Opcional | Defina como true para aplicar a política. Defina como false para desativar a política. A política não será aplicada mesmo que permaneça vinculada a um fluxo. |
async |
falso | Obsoleto | Esse atributo está obsoleto. |
Referência de elemento secundário
Esta secção descreve os elementos subordinados de<AssertCondition>.
<Condition>
Especifica a condição a avaliar. Para mais informações sobre como escrever uma declaração condicional no Apigee, consulte a Referência de condições.
| Valor predefinido | N/A |
| Obrigatório? | Obrigatória |
| Tipo | String |
| Elemento principal |
<AssertCondition>
|
| Elementos subordinados | Nenhum |
<DisplayName>
Use em conjunto com o atributo name para etiquetar a política no editor de proxy da IU de gestão com um nome diferente e mais natural.
O elemento <DisplayName> é comum a todas as políticas.
| Valor predefinido | N/A |
| Obrigatório? | Opcional. Se omitir <DisplayName>, é usado o valor do atributo name da política. |
| Tipo | String |
| Elemento principal | <PolicyElement> |
| Elementos subordinados | Nenhum |
O elemento <DisplayName> usa a seguinte sintaxe:
Sintaxe
<PolicyElement> <DisplayName>POLICY_DISPLAY_NAME</DisplayName> ... </PolicyElement>
Exemplo
<PolicyElement> <DisplayName>My Validation Policy</DisplayName> </PolicyElement>
O elemento <DisplayName> não tem atributos nem elementos subordinados.
Códigos de erro
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 |
|---|---|---|
steps.assertcondition.ConditionEvaluationFailed |
500 |
Failed to evaluate the conditional statement. There can be many reasons for this error, including incorrect values in the variables at run time. |
Deployment errors
These errors can occur when you deploy a proxy containing this policy.
| Error name | Cause |
|---|---|
InvalidCondition |
The policy was not able to validate the conditional statement. There can be many reasons for this error, including malformed conditions or use of unsupported operators. |
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.
The following table describes the fault variables specific to this policy.
| Variables | Where | Example |
|---|---|---|
fault.name="FAULT_NAME" |
FAULT_NAME is the name of the fault, as listed in the Runtime errors table. The fault name is the last part of the fault code. | fault.name Matches "ConditionEvaluationFailed" |
AssertCondition.POLICY_NAME.failed |
POLICY_NAME is the user-specified name of the policy that threw the fault. | AssertCondition.My-AssertCondition.failed = true |