> For the complete documentation index, see [llms.txt](https://docs.skyone.cloud/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://docs.skyone.cloud/espanol/skyone-studio/integraciones/flujos/gestion-de-los-flujos/flow-canva-configuracion-y-edicion-del-flujo/flujos-multicontexto.md).

# Flujos Multicontexto

Los ***Flujos Multicontexto*** permiten utilizar el mismo flujo en diversos contextos. Cada contexto tiene sus propios valores de variables de flujo y sus propias cuentas. A través de los flujos multicontexto, puedes activar el mismo flujo para distintos socios, clientes o usuarios, especificando las cuentas de cada uno. Es una forma sencilla de usar la misma integración para diferentes entidades bajo el control de una sola cuenta.

***

### Definiciones

Es más fácil explicar el ***Flujo Multicontexto*** con un escenario en el que necesitamos ejecutar el mismo flujo para dos cuentas diferentes. Imagina que una integración se ejecuta periódicamente y actualiza la base de datos de un cliente. Ahora imagina que otro cliente quiere utilizar la misma integración, pero debemos guardar la información en la base de datos de este otro cliente.

Con el ***Flujo Multicontexto*** podemos utilizar el mismo flujo para ejecutar la función en ambas empresas. Claro que necesitaremos indicar al flujo:

* **Contexto:** En este caso, habrá un contexto para cada cliente.
* **Clave de Contexto:** Es la variable que permite identificar el contexto. Puede ser un identificador de cliente. A través de esta clave se identifican todas las variables y cuentas del contexto.
* **Variables de Contexto:** Podemos crear variables de flujo configuradas por contexto. Es decir, los valores de estas variables son especificados individualmente para cada cliente.
* **Cuentas de Contexto:** Podemos crear cuentas de acceso (Base de Datos, API REST, etc.) para cada contexto. De esta manera, el flujo utilizará las cuentas específicas de un cliente cuando se ejecute en el contexto de ese cliente.

Un ***Flujo Multicontexto*** tiene al menos un ***Localizador de Contexto*** o ***Context Finder***. Durante la ejecución del flujo invocamos el ***Context Finder*** pasando una clave de identificación de contexto. El ***Context Finder*** tiene como objetivo localizar el contexto a partir de la clave proporcionada. Una vez localizado, devuelve todos los valores de parámetros y cuentas específicos de ese contexto. Los módulos posteriores pueden usar las variables y cuentas de cada contexto.

<figure><img src="/files/EalcsWxdaLR0Y00JKXb3" alt=""><figcaption></figcaption></figure>

***

### Configurar un flujo multicontexto

La construcción de un flujo multicontexto debe seguir exactamente los mismos pasos que un flujo convencional. Una vez probado, el flujo convencional puede convertirse en multicontexto.

[**\[ Paso 01 \]** Construir el flujo convencional monocontenido](#paso-01-construir-el-flujo-convencional-monocontenido)\
[**\[ Paso 02 \]** Introducir el *Context Finder* en el flujo](#paso-02-introducir-el-context-finder-en-el-flujo)\
[**\[ Paso 03 \]** Seleccionar las variables que deben cambiar según el contexto](#paso-03-seleccionar-las-variables-de-flujo-que-deben-cambiar-segun-el-contexto)\
[**\[ Paso 04 \]** Seleccionar las cuentas que deben cambiar según el contexto](#paso-04-seleccionar-las-cuentas-que-deben-cambiar-segun-el-contexto)\
[**\[ Paso 05 \]** Configurar las cuentas de cada contexto](#paso-05-configurar-las-cuentas-de-cada-contexto)\
[**\[ Paso 06 \]** Crear los contextos y sus claves](#paso-06-crear-los-contextos-y-sus-claves)\
[**\[ Paso 07 \]** Configurar las variables de flujo y asignar las cuentas de cada contexto](#paso-07-configurar-variables-de-flujo-y-asignar-cuentas)\
[**\[ Paso 08 \]** Logs de ejecución del flujo multicontexto](#paso-08-ejecutar-el-flujo-multicontexto)

***

## Paso a Paso

### **Paso 01: Construir el flujo convencional monocontenido**

Construye tu flujo de manera convencional utilizando las variables de flujo y las cuentas como si este flujo fuera a atender solo un contexto.

Puedes definir un contexto predeterminado. Como sugerencia, crea el flujo convencional con las variables y cuentas que serán utilizadas por este contexto por defecto.

<figure><img src="/files/G2bpit4u2vpv5x9Ux7TE" alt=""><figcaption></figcaption></figure>

### **Paso 02: Introducir el&#x20;*****Context Finder*****&#x20;en el flujo**

El *Context Finder* recibe una clave y, con ella, encuentra el conjunto de variables de flujo y cuentas conectadas que deben utilizarse en la ejecución del flujo.

Normalmente, el *Context Finder* se coloca al inicio de la ejecución del flujo, pero puede ubicarse en cualquier punto del mismo. Lo importante es que esté antes de los módulos que usan variables de flujo y cuentas conectadas dependientes del contexto.

También es importante asegurar que la clave de contexto ya esté disponible para poder pasársela al *Context Finder*. Usualmente esta clave puede venir de un [*Webhook Trigger*](/espanol/skyone-studio/integraciones/flujos/disparadores/disparadores-webhook-adicion-y-configuracion.md) o de una llamada a una API del API Gateway, pero también puede provenir de cualquier módulo, incluso de una variable de flujo.

<figure><img src="/files/kP9cWjfDqn95p0uQwC9M" alt=""><figcaption></figcaption></figure>

**Módulo Context Finder**\
El módulo *Context Finder* requiere que el operador proporcione únicamente la clave (*key*) que será utilizada para localizar el contexto. Especifica la variable que servirá como clave en el campo *Identificador de Contexto*.

<figure><img src="/files/MLPoH3jp73Y4pNXBbGl1" alt=""><figcaption></figcaption></figure>

### **Paso 03: Seleccionar las variables de flujo que deben cambiar según el contexto**

Debes indicar las variables que se modifican de acuerdo con el contexto.

Para que una variable de flujo también sea de contexto, basta con editar la variable en **Contextos → Variables → Agregar variables**.

Las variables creadas en “Contexto” se muestran en una pestaña exclusiva dentro de **Configuración**.

### **Paso 04: Seleccionar las cuentas que deben cambiar según el contexto**

Debes indicar las cuentas que cambian de acuerdo con el contexto. Todas las cuentas de los módulos que se ejecutan después del *Context Finder* pueden especificarse.

{% hint style="warning" %}
Asegúrate de haber introducido el *Context Finder* en tu flujo; de lo contrario, no podrás indicar cuentas dependientes de contexto.
{% endhint %}

Al revisar tu flujo, abre la configuración de los módulos que requieren cuentas conectadas (Bases de Datos, APIs REST, etc.).

Ahora esos módulos permiten que asocies una cuenta a un contexto. Selecciona la opción **Usar cuenta de contexto**.

<figure><img src="/files/VXUsWOYdQA9a6kz931oZ" alt=""><figcaption></figcaption></figure>

Luego, aparecerá la opción **Configurar cuenta conectada de contexto**.

<figure><img src="/files/dQDXlBxTVEfY9oiyCvFo" alt=""><figcaption></figcaption></figure>

{% hint style="info" %}
El Skyone Studio utiliza la cuenta original creada en el **PASO 01** y la asigna al contexto *Default*.
{% endhint %}

Observa que en este momento puedes crear otras cuentas de contexto, pero lo haremos más adelante. Puedes hacer clic en **"Siguiente"** para avanzar a la página de prueba del módulo.

<figure><img src="/files/jgtxCMOrfY1uyFK74vcb" alt=""><figcaption></figcaption></figure>

Observa que ahora es posible seleccionar la cuenta de contexto para ejecutar la prueba. Como aún no hemos configurado ningún contexto, solo la cuenta **Default** está disponible.

### **Paso 05: Configurar las cuentas de cada contexto**

Las cuentas de acceso siguen configurándose de la misma forma. Deberás configurar una cuenta para cada contexto, que luego será referenciada en la edición del contexto.

{% hint style="info" %}
Todos los tipos de cuentas disponibles en Skyone Studio pueden ser accesibles desde los contextos.
{% endhint %}

<figure><img src="/files/Nf00J6h4wxnKNyqOVGRp" alt=""><figcaption></figcaption></figure>

### **Paso 06: Crear los contextos y sus claves**

Existe un área específica para la configuración de los contextos. Cada contexto corresponde a una entidad diferente que posee sus propias cuentas y variables específicas. Por ejemplo, cada contexto puede representar un cliente distinto con sus cuentas de acceso a bases de datos y variables de flujo específicas. En este paso, debes crear los contextos y definir una clave que permita identificar cada uno, como por ejemplo, un identificador de cliente.

Selecciona la opción **"Contexto"** en la pantalla principal de edición del flujo.

En el modo de edición de Contextos, puedes crear, editar y eliminar contextos. La primera vez que accedes, solo el contexto predeterminado (**Default**) está disponible. Puedes hacer clic en **"Agregar contexto"** para añadir un nuevo contexto.

<figure><img src="/files/tA500lKYsl2Ov592jSEm" alt=""><figcaption></figcaption></figure>

Al crear un nuevo contexto, puedes definir un nombre y una clave (*key*) para tu contexto. El nombre es solo una referencia para que el operador pueda localizar el contexto. La clave es la información que se utilizará para localizar este contexto. Funciona como un indexador y debe ser única para este flujo.

<figure><img src="/files/8kWHrz2VQg71UnCe1xT1" alt=""><figcaption></figcaption></figure>

Al guardar este contexto, podrás verlo en la lista de contextos disponibles.

### **Paso 07: Configurar variables de flujo y asignar cuentas**

En este paso configuras las variables de flujo y cuentas de cada contexto.

Haz clic en el lápiz de edición del contexto que quieres modificar.

<figure><img src="/files/ArNOKiSjL0h75QNy0xND" alt=""><figcaption></figcaption></figure>

Observa que ahora podrás editar las variables y cuentas conectadas del contexto seleccionado. Todas las variables de flujo que fueron convertidas a *Context Parameter* para variables de contexto en el **PASO 02** aparecerán automáticamente para que puedas definir sus valores.

<figure><img src="/files/ycMyhpfYBJpEWWsEDF3l" alt=""><figcaption></figcaption></figure>

De la misma manera, las Cuentas Conectadas también pueden definirse en este paso. Haz clic en **"Cuentas Conectadas"**.

<figure><img src="/files/VggwL5vsJkCcBZA3UEOZ" alt=""><figcaption></figcaption></figure>

Podrás definir qué cuenta se utilizará para cada uno de los componentes que requieren cuentas conectadas por contexto. Tendrás que realizar esta configuración para cada uno de los contextos que crees.

### **Paso 08: Ejecutar el flujo multicontexto**

Ejecuta el flujo igual que un flujo convencional, asegurándote de que la clave se pase correctamente al *Context Finder*.

Los logs de los flujos multicontexto contienen información adicional sobre la localización de contextos y los valores obtenidos en cada ejecución.


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://docs.skyone.cloud/espanol/skyone-studio/integraciones/flujos/gestion-de-los-flujos/flow-canva-configuracion-y-edicion-del-flujo/flujos-multicontexto.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
