Recupera vínculos de linaje de varias regiones

En el siguiente pseudocódigo, se describe un procedimiento que puedes seguir con la API de Data Lineage para recuperar vínculos de linaje de datos de todas las regiones disponibles.

  1. Configuración de entrada:
    • linksToFetch = 5 (cantidad de vínculos que se recuperarán de todas las regiones)
    • regionalPageToken = "" (el último token de página regional recibido que se usa para la paginación)
  2. Crear:
    1. lista de todas las regiones para el fan-out llamada regions.
    2. lista de regiones inaccesibles llamada unreachable.
    3. una lista vacía de vínculos encontrados llamada foundLinks.
    4. una variable vacía nextPageToken y nextRegionalPageToken.
    5. una variable vacía lastRegion.
    6. una variable vacía lastRegionLinksCount.
  3. Ordena regions alfabéticamente.
  4. Analiza regionalPageToken
    1. Si está vacío, continúa con el paso 5.
    2. Si no está vacío, haz lo siguiente:
      1. Analiza regionalPageToken dividiéndolo por el primer punto en dos segmentos.
      2. Filtra las regiones tomando solo las que están después (en orden alfabético) del primer segmento del regionalPageToken analizado.
      3. Almacena el segundo segmento para usarlo en todas las llamadas a projects.locations.searchLinks.
  5. Realiza una llamada a projects.locations.searchLinks en cada región de la lista regions en paralelo.
  6. Espera a que se completen todas las solicitudes.
  7. Filtra las respuestas correctas y almacena los nombres de las regiones con errores en la lista unreachable.
  8. Para cada una de las respuestas (comenzando por la primera región en orden alfabético), haz lo siguiente:
    1. si no se devolvieron vínculos junto con un token de página no vacío
      1. Almacena el nombre de la región en lastRegion.
      2. guarda el pageToken recibido en nextPageToken.
      3. Ignora las respuestas restantes.
    2. otherwise
      1. Almacena el nombre de la región en lastRegion.
      2. guardar los vínculos recibidos en foundLinks (hasta linksToFetch).
      3. guarda el pageToken recibido en nextPageToken.
      4. Almacena la cantidad de vínculos tomados de la respuesta en lastRegionLinksCount.
      5. si foundLinks es menor que linksToFetch
        1. continúa el pseudocódigo con la siguiente respuesta recibida en orden alfabético.
      6. si foundLinks es igual a linksToFetch
        1. Realiza otra solicitud al extremo projects.locations.searchLinks en la misma región, pero establece el parámetro pageSize en el valor de lastRegionLinksCount.
        2. store recibió el pageToken en nextPageToken.
        3. continúa con el paso 9
  9. Agrega nextPageToken al principio con lastRegion (es decir, [region].[receivedNextPageToken]) para crear nextRegionalPageToken y controlar la paginación en llamadas consecutivas.