Accede a variables de flujo en Node.js

Estás viendo la documentación de Apigee Edge.
Ve a la documentación de Apigee X.
info

Introducción

Usa el módulo apigee-access para acceder a las variables de flujo de Apigee Edge en una aplicación de Node.js. El módulo tiene métodos para obtener, configurar y borrar variables. También tiene un método de conveniencia para establecer una variable de tipo entero.

Las variables de flujo existen dentro del contexto de un flujo de proxy de API. Algunas variables están "integradas" en Edge. Otras se crean cuando se ejecutan las políticas, y puedes crear tus propias variables. Por lo general, las variables de flujo se usan para pasar datos de una política a otra y para configurar condiciones en flujos condicionales. Para obtener información sobre las variables de flujo, consulta Variables y condiciones de flujo.

Para obtener una introducción al módulo apigee-access y sus otras funciones, consulta Cómo usar el módulo apigee-access.

Ejemplo de trabajo

Imagina que una política de Edge que se ejecuta en la ruta de flujo de solicitudes establece una variable llamada AuthenticatedUserId. El siguiente código accede a esa variable y la imprime en un registro. Además, este código establece una variable. Luego, puedes acceder a esa variable desde una política, que ilustramos a continuación.

var http = require('http');
var apigee = require('apigee-access');

http.createServer(function (request, response) {
  // The request parameter must be a request object that came from the http module
  var userId = apigee.getVariable(request, 'AuthenticatedUserId');
  apigee.setVariable(request, "custom.foo", "Bar");
  console.log('Authenticated Apigee User ID is %s', userId);
  response.writeHead(200, {'Content-Type': 'text/plain'});
  response.end('Hello World\n');
}).listen(8124);

console.log('Server running at http://127.0.0.1:8124/');

Puedes copiar este código en un archivo JavaScript, implementarlo en Edge y probarlo. Llama al archivo server.js. Para implementarlo, usa lo siguiente:

apigeetool deploynodeapp -u username -p password -o myorg -e test -n access -d . -m server.js -b /access

Después de implementar la aplicación en Edge, agrega una políticaAssignMessage con la siguiente configuración al flujo de solicitudes de ProxyEndpoint:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssignMessage async="false" continueOnError="false" enabled="true" name="AddUserId">
    <DisplayName>AddUserId</DisplayName>
    <FaultRules/>
    <Properties/>  
    <AssignVariable>
        <Name>AuthenticatedUserId</Name>
        <Value>ntesla</Value>
        <Ref/>
    </AssignVariable>
    <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
    <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>

A continuación, adjunta otra política de AssignMessage al preflujo de respuesta de TargetEndpoint:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssignMessage async="false" continueOnError="false" enabled="true" name="SetHeader">
    <DisplayName>SetHeader</DisplayName>
    <FaultRules/>
    <Properties/>
    <Set>
        <Headers>
            <Header name="MySpecialHeader">{custom.foo}</Header>
        </Headers>
    </Set>
    <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables>
    <AssignTo createNew="false" transport="http" type="request"/>
</AssignMessage>

Puedes llamar al proxy de la siguiente manera:

curl -i http://myorg-test.apigee.net/access

Ahora, ve a la página del proxy de acceso en la IU de administración y abre la vista Desarrollar. Haz clic en Registros de Node.js para ver el resultado del registro desde el proxy. Si el proxy está configurado correctamente, verás que se configuró la variable userId. También verás que el encabezado se configuró en el resultado de cURL en la ventana de terminal:

HTTP/1.1 200 OK

Content-Type: text/plain
Date: Tue, 27 05 2014 23:20:52 GMT
MySpecialHeader: Bar
Content-Length: 12
Connection: keep-alive

Métodos


getVariable

var result = getVariable(httpRequest, name);

Obtiene una variable con nombre.

Parámetros:

  • httpRequest: Es el objeto de solicitud que proviene del módulo http.
  • name: (Cadena) Es el nombre de la variable que se recuperará.

Muestra:

Es una cadena o un número, según el tipo que se configuró con setVariable(), cuando tú lo creaste en otro lugar o cuando lo creó una política. Si accedes a una de las variables de Edge listas para usar, encontrarás una lista de tipos en la Referencia de variables. Para conocer los tipos de variables que crean las políticas, consulta el tema de referencia de la política específico.

Ejemplos:

var apigee = require('apigee-access');
    // "httpRequest" must be a request object that came from the http module
    var val1 = apigee.getVariable(request, 'TestVariable');
    var val2 = apigee.getVariable(request, 'request.client.ip');

setVariable

setVariable(httpRequest, name, value);

Establece una variable. Algunas variables son de solo lectura, y el método setVariable() arroja una excepción si intentas establecer una de ellas. Para determinar qué variables son de solo lectura, consulta la referencia de variables.

Parámetros:

  • httpRequest: Es el objeto de solicitud que proviene del módulo http.
  • name: (Cadena) Es el nombre de la variable que se recuperará.
  • value: Puede ser un número, una cadena, un valor booleano, un valor nulo o un valor indefinido.

Ejemplo:

var apigee = require('apigee-access');
    apigee.setVariable(request, 'TestVariable', 'bar');
    // This will throw an exception because client.ip is read-only.
    apigee.setVariable(request, 'client.ip');
    

setIntVariable

setIntVariable(httpRequest, name, value);

El método setIntVariable() es un método de conveniencia que primero convierte el parámetro de valor en un número entero y luego lo establece.

Parámetros:

  • httpRequest: Es el objeto de solicitud que proviene del módulo http.
  • name: (String) Es el nombre de la variable que se configurará.
  • value: El parámetro de valor debe ser una cadena o un número.

Ejemplo:

var apigee = require('apigee-access');
// Convert "123" to an integer and set it
apigee.setIntVariable(request, 'TestVariable', '123');
// Use something that's already a number
apigee.setIntVariable(request, 'TestVariable2', 42);

deleteVariable

Borra una variable con nombre. Borrar una variable de solo lectura es un error. Para obtener una lista completa de las variables de solo lectura, consulta la Referencia de variables.

deleteVariable(httpRequest, name);

Parámetros:

  • httpRequest: Es el objeto de solicitud que proviene del módulo http.
  • name: (String) El nombre de la variable que se borrará.

Ejemplo:

  apigee.deleteVariable(request, 'TestVariable');
    // This will throw an exception because client.ip is a read-only variable.
    apigee.deleteVariable(request, 'client.ip');