mirror of
https://github.com/FlipsideCrypto/flow-models.git
synced 2026-02-06 20:21:49 +00:00
Some checks failed
docs_update / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_evm_daily_realtime / run_dbt_jobs (push) Has been cancelled
dbt_run_moments_metadata / run_dbt_jobs (push) Has been cancelled
dbt_observability_models / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_evm_daily_silver / run_dbt_jobs (push) Has been cancelled
dbt_run_evm_decoded_logs / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_transactions / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_transaction_results / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_external_realtime / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_external_points_balances_realtime / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_evm_realtime / run_dbt_jobs (push) Has been cancelled
dbt_run_scheduled / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_blocks / run_dbt_jobs (push) Has been cancelled
dbt_run_evm / run_dbt_jobs (push) Has been cancelled
dbt_run_scheduled_non_core / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_collections / run_dbt_jobs (push) Has been cancelled
docs_update / notify-failure (push) Has been cancelled
dbt_run_streamline_evm_daily_realtime / notify-failure (push) Has been cancelled
dbt_run_moments_metadata / notify-failure (push) Has been cancelled
dbt_observability_models / notify-failure (push) Has been cancelled
dbt_run_streamline_evm_daily_silver / notify-failure (push) Has been cancelled
dbt_run_evm_decoded_logs / notify-failure (push) Has been cancelled
dbt_run_streamline_transactions / notify-failure (push) Has been cancelled
dbt_run_streamline_transaction_results / notify-failure (push) Has been cancelled
dbt_run_streamline_external_realtime / notify-failure (push) Has been cancelled
dbt_run_streamline_external_points_balances_realtime / notify-failure (push) Has been cancelled
dbt_run_streamline_evm_realtime / notify-failure (push) Has been cancelled
dbt_run_scheduled / notify-failure (push) Has been cancelled
dbt_run_streamline_blocks / notify-failure (push) Has been cancelled
dbt_run_evm / notify-failure (push) Has been cancelled
dbt_run_scheduled_non_core / notify-failure (push) Has been cancelled
dbt_run_streamline_collections / notify-failure (push) Has been cancelled
dbt_run_streamline_decoded_logs_history / run_dbt_jobs (push) Has been cancelled
dbt_run_streamline_decoded_logs_history / notify-failure (push) Has been cancelled
* upd incr predicate on silver core models * upd rest of the models * rm predicate from d+i model
170 lines
4.6 KiB
SQL
170 lines
4.6 KiB
SQL
-- depends_on: {{ ref('bronze__streamline_blocks') }}
|
|
-- depends_on: {{ ref('bronze__streamline_blocks_history') }}
|
|
|
|
{{ config(
|
|
materialized = 'incremental',
|
|
unique_key = "block_number",
|
|
incremental_strategy = 'merge',
|
|
incremental_predicates = ["dynamic_range_predicate", "_partition_by_block_id"],
|
|
merge_exclude_columns = ["inserted_timestamp"],
|
|
cluster_by = "block_timestamp::date",
|
|
tags = ['streamline_load', 'core', 'scheduled_core']
|
|
) }}
|
|
|
|
WITH
|
|
|
|
{% if is_incremental() and not var('LOAD_BACKFILL', False) %}
|
|
tx_count_lookback AS (
|
|
-- lookback to ensure tx count is correct
|
|
|
|
SELECT
|
|
block_height
|
|
FROM
|
|
{{ this }}
|
|
WHERE
|
|
block_height >= {{ var(
|
|
'STREAMLINE_START_BLOCK'
|
|
) }} -- TODO, remove AFTER backfill is complete
|
|
-- limit to 3 day lookback for performance
|
|
AND _inserted_timestamp >= SYSDATE() - INTERVAL '3 days'
|
|
AND (
|
|
tx_count IS NULL
|
|
OR collection_count != collection_count_agg
|
|
)
|
|
),
|
|
{% endif %}
|
|
|
|
streamline_blocks AS (
|
|
SELECT
|
|
block_number,
|
|
DATA: height :: STRING AS block_height,
|
|
DATA: id :: STRING AS block_id,
|
|
DATA :timestamp :: timestamp_ntz AS block_timestamp,
|
|
ARRAY_SIZE(
|
|
DATA :collection_guarantees :: ARRAY
|
|
) AS collection_count,
|
|
DATA: parent_id :: STRING AS parent_id,
|
|
DATA: signatures :: ARRAY AS signatures,
|
|
DATA: collection_guarantees :: ARRAY AS collection_guarantees,
|
|
DATA: block_seals :: ARRAY AS block_seals,
|
|
_partition_by_block_id,
|
|
_inserted_timestamp
|
|
FROM
|
|
{% if var('LOAD_BACKFILL', False) %}
|
|
{{ ref('bronze__streamline_blocks_history') }}
|
|
-- TODO need incremental logic of some sort probably (for those 5800 missing txs)
|
|
-- where inserted timestamp >= max from this where network version = backfill version OR block range between root and end
|
|
{% else %}
|
|
{% if is_incremental() %}
|
|
{{ ref('bronze__streamline_blocks') }}
|
|
WHERE
|
|
_inserted_timestamp >= (
|
|
SELECT
|
|
MAX(_inserted_timestamp) _inserted_timestamp
|
|
FROM
|
|
{{ this }}
|
|
)
|
|
OR block_height IN (
|
|
SELECT
|
|
block_height
|
|
FROM
|
|
tx_count_lookback
|
|
)
|
|
{% else %}
|
|
{{ ref('bronze__streamline_fr_blocks') }}
|
|
{% endif %}
|
|
{% endif %}
|
|
|
|
qualify(ROW_NUMBER() over (PARTITION BY block_number
|
|
ORDER BY
|
|
_inserted_timestamp DESC)) = 1
|
|
),
|
|
network_version AS (
|
|
SELECT
|
|
root_height,
|
|
network_version,
|
|
COALESCE(LAG(root_height) over (
|
|
ORDER BY
|
|
network_version DESC) - 1, 'inf' :: FLOAT) AS end_height
|
|
FROM
|
|
{{ ref('seeds__network_version') }}
|
|
),
|
|
collections AS (
|
|
SELECT
|
|
*
|
|
FROM
|
|
{{ ref('silver__streamline_collections') }}
|
|
{% if var('LOAD_BACKFILL', False) %}
|
|
WHERE
|
|
block_number between (
|
|
SELECT root_height FROM network_version WHERE lower(network_version) = lower('{{ var('LOAD_BACKFILL_VERSION').replace('_', '-') }}')
|
|
) AND (
|
|
SELECT end_height FROM network_version WHERE lower(network_version) = lower('{{ var('LOAD_BACKFILL_VERSION').replace('_', '-') }}')
|
|
)
|
|
{% else %}
|
|
{% if is_incremental() %}
|
|
WHERE
|
|
_inserted_timestamp >= (
|
|
SELECT
|
|
MAX(_inserted_timestamp)
|
|
FROM
|
|
{{ this }}
|
|
)
|
|
OR block_number IN (
|
|
SELECT
|
|
block_height
|
|
FROM
|
|
tx_count_lookback
|
|
)
|
|
{% endif %}
|
|
{% endif %}
|
|
),
|
|
tx_count AS (
|
|
SELECT
|
|
block_number AS block_height,
|
|
SUM(tx_count) AS tx_count,
|
|
COUNT(1) AS collection_count,
|
|
MIN(_inserted_timestamp) AS _inserted_timestamp
|
|
FROM
|
|
collections
|
|
GROUP BY
|
|
1
|
|
),
|
|
FINAL AS (
|
|
SELECT
|
|
b.block_number,
|
|
b.block_height,
|
|
v.network_version,
|
|
b.block_id AS id,
|
|
b.block_timestamp,
|
|
b.collection_count,
|
|
IFF(
|
|
b.collection_count = 0,
|
|
b.collection_count,
|
|
C.tx_count
|
|
) AS tx_count,
|
|
b.parent_id,
|
|
b.signatures,
|
|
b.collection_guarantees,
|
|
b.block_seals,
|
|
C.collection_count AS collection_count_agg,
|
|
b._partition_by_block_id,
|
|
{{ dbt_utils.generate_surrogate_key(
|
|
['block_number']
|
|
) }} AS blocks_id,
|
|
SYSDATE() AS inserted_timestamp,
|
|
SYSDATE() AS modified_timestamp,
|
|
'{{ invocation_id }}' AS _invocation_id,
|
|
b._inserted_timestamp
|
|
FROM
|
|
streamline_blocks b
|
|
LEFT JOIN network_version v
|
|
ON b.block_height BETWEEN v.root_height
|
|
AND v.end_height
|
|
LEFT JOIN tx_count C USING (block_height)
|
|
)
|
|
SELECT
|
|
*
|
|
FROM
|
|
FINAL
|