-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* initial models * docs * docs and tests * overview docs * updates for service reads * coalesce * metadata join * row num * heal * inc * remove test * rebuild * key * remove docs
- Loading branch information
1 parent
db7d483
commit a47e759
Showing
14 changed files
with
875 additions
and
0 deletions.
There are no files selected for viewing
153 changes: 153 additions & 0 deletions
153
models/silver/protocols/olas/metadata/silver_olas__getservice_reads.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,153 @@ | ||
{{ config( | ||
materialized = 'incremental', | ||
incremental_strategy = 'delete+insert', | ||
unique_key = 'getservice_reads_id', | ||
full_refresh = false, | ||
tags = ['curated'] | ||
) }} | ||
|
||
WITH service_contracts AS ( | ||
|
||
SELECT | ||
contract_address, | ||
service_id AS registry_id, | ||
MAX(block_number) AS block_number | ||
FROM | ||
{{ ref('silver_olas__service_registrations') }} | ||
|
||
{% if is_incremental() %} | ||
WHERE | ||
_inserted_timestamp >= ( | ||
SELECT | ||
MAX(_inserted_timestamp) - INTERVAL '12 hours' | ||
FROM | ||
{{ this }} | ||
) | ||
AND CONCAT( | ||
contract_address, | ||
'-', | ||
registry_id | ||
) NOT IN ( | ||
SELECT | ||
CONCAT( | ||
contract_address, | ||
'-', | ||
function_input | ||
) | ||
FROM | ||
{{ this }} | ||
) | ||
{% endif %} | ||
GROUP BY | ||
1, | ||
2 | ||
), | ||
function_sigs AS ( | ||
SELECT | ||
'0xef0e239b' AS function_sig, | ||
'getService' AS function_name | ||
), | ||
inputs AS ( | ||
SELECT | ||
contract_address, | ||
block_number, | ||
function_sig, | ||
function_name, | ||
registry_id AS function_input, | ||
CONCAT( | ||
function_sig, | ||
LPAD( | ||
SUBSTR(utils.udf_int_to_hex(function_input), 3), | ||
64, | ||
0) | ||
) AS DATA | ||
FROM | ||
service_contracts | ||
JOIN function_sigs | ||
ON 1 = 1 | ||
), | ||
contract_reads AS ( | ||
SELECT | ||
contract_address, | ||
block_number, | ||
function_sig, | ||
function_name, | ||
function_input, | ||
DATA, | ||
utils.udf_json_rpc_call( | ||
'eth_call', | ||
[{ 'to': contract_address, 'from': null, 'data': data }, utils.udf_int_to_hex(block_number) ] | ||
) AS rpc_request, | ||
live.udf_api( | ||
node_url, | ||
rpc_request | ||
) AS read_output, | ||
SYSDATE() AS _inserted_timestamp | ||
FROM | ||
inputs | ||
JOIN {{ source( | ||
'streamline_crosschain', | ||
'node_mapping' | ||
) }} | ||
ON 1 = 1 | ||
AND chain = 'polygon' | ||
), | ||
reads_flat AS ( | ||
SELECT | ||
read_output, | ||
read_output :data :id :: STRING AS read_id, | ||
read_output :data :result :: STRING AS read_result, | ||
SPLIT( | ||
read_id, | ||
'-' | ||
) AS read_id_object, | ||
regexp_substr_all(SUBSTR(read_result, 3, len(read_result)), '.{64}') AS segmented_read, | ||
utils.udf_hex_to_int( | ||
VALUE :: STRING | ||
) AS decoded_read, | ||
function_sig, | ||
function_name, | ||
function_input, | ||
DATA, | ||
contract_address, | ||
block_number, | ||
_inserted_timestamp | ||
FROM | ||
contract_reads, | ||
LATERAL FLATTEN( | ||
input => segmented_read | ||
) | ||
), | ||
reads_final AS ( | ||
SELECT | ||
read_output, | ||
read_id, | ||
read_result, | ||
read_id_object, | ||
segmented_read, | ||
function_sig, | ||
function_name, | ||
function_input, | ||
DATA, | ||
contract_address, | ||
block_number, | ||
_inserted_timestamp, | ||
ARRAY_AGG(TRY_TO_NUMBER(decoded_read)) AS reads_array, | ||
ARRAY_SLICE(reads_array, 9, ARRAY_SIZE(reads_array)) AS agent_ids | ||
FROM | ||
reads_flat | ||
GROUP BY | ||
ALL) | ||
SELECT | ||
*, | ||
{{ dbt_utils.generate_surrogate_key( | ||
['contract_address','function_input'] | ||
) }} AS getservice_reads_id, | ||
SYSDATE() AS inserted_timestamp, | ||
SYSDATE() AS modified_timestamp, | ||
'{{ invocation_id }}' AS _invocation_id | ||
FROM | ||
reads_final | ||
WHERE | ||
agent_ids IS NOT NULL | ||
AND agent_ids :: STRING <> '[]' |
17 changes: 17 additions & 0 deletions
17
models/silver/protocols/olas/metadata/silver_olas__getservice_reads.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
version: 2 | ||
models: | ||
- name: silver_olas__getservice_reads | ||
tests: | ||
- dbt_utils.unique_combination_of_columns: | ||
combination_of_columns: | ||
- GETSERVICE_READS_ID | ||
columns: | ||
- name: BLOCK_NUMBER | ||
tests: | ||
- not_null | ||
- name: FUNCTION_INPUT | ||
tests: | ||
- not_null | ||
- name: AGENT_IDS | ||
tests: | ||
- not_null |
146 changes: 146 additions & 0 deletions
146
models/silver/protocols/olas/metadata/silver_olas__registry_metadata.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,146 @@ | ||
{{ config( | ||
materialized = 'incremental', | ||
incremental_strategy = 'delete+insert', | ||
unique_key = 'registry_metadata_id', | ||
full_refresh = false, | ||
tags = ['curated'] | ||
) }} | ||
|
||
WITH new_records AS ( | ||
|
||
SELECT | ||
block_number, | ||
contract_address, | ||
function_input AS registry_id, | ||
token_uri_link, | ||
_inserted_timestamp, | ||
ROW_NUMBER() over ( | ||
ORDER BY | ||
contract_address, | ||
registry_id | ||
) AS row_num | ||
FROM | ||
{{ ref('silver_olas__registry_reads') }} | ||
|
||
{% if is_incremental() %} | ||
WHERE | ||
_inserted_timestamp > ( | ||
SELECT | ||
MAX(_inserted_timestamp) | ||
FROM | ||
{{ this }} | ||
) | ||
OR | ||
CONCAT( | ||
contract_address, | ||
'-', | ||
registry_id | ||
) IN ( | ||
SELECT | ||
CONCAT( | ||
contract_address, | ||
'-', | ||
registry_id | ||
) | ||
FROM | ||
{{ this }} | ||
WHERE | ||
NAME IS NULL | ||
) | ||
{% endif %} | ||
), | ||
uri_calls AS ( | ||
SELECT | ||
block_number, | ||
contract_address, | ||
registry_id, | ||
token_uri_link, | ||
live.udf_api(token_uri_link) AS resp, | ||
_inserted_timestamp | ||
FROM | ||
new_records | ||
WHERE | ||
row_num <= 100 | ||
UNION ALL | ||
SELECT | ||
block_number, | ||
contract_address, | ||
registry_id, | ||
token_uri_link, | ||
live.udf_api(token_uri_link) AS resp, | ||
_inserted_timestamp | ||
FROM | ||
new_records | ||
WHERE | ||
row_num > 100 | ||
AND row_num <= 200 | ||
UNION ALL | ||
SELECT | ||
block_number, | ||
contract_address, | ||
registry_id, | ||
token_uri_link, | ||
live.udf_api(token_uri_link) AS resp, | ||
_inserted_timestamp | ||
FROM | ||
new_records | ||
WHERE | ||
row_num > 200 | ||
), | ||
response AS ( | ||
SELECT | ||
resp, | ||
block_number, | ||
contract_address, | ||
registry_id, | ||
token_uri_link, | ||
resp :data :attributes [0] :trait_type :: STRING AS trait_type, | ||
resp :data :attributes [0] :value :: STRING AS trait_value, | ||
REPLACE( | ||
resp :data :code_uri :: STRING, | ||
'ipfs://', | ||
'https://gateway.autonolas.tech/ipfs/' | ||
) AS code_uri_link, | ||
resp :data :description :: STRING AS description, | ||
CASE | ||
WHEN resp :data :image :: STRING ILIKE 'ipfs://%' THEN REPLACE( | ||
resp :data :image :: STRING, | ||
'ipfs://', | ||
'https://gateway.autonolas.tech/ipfs/' | ||
) | ||
WHEN resp :data :image :: STRING NOT ILIKE '%://%' THEN CONCAT( | ||
'https://gateway.autonolas.tech/ipfs/', | ||
resp :data :image :: STRING | ||
) | ||
ELSE resp :data :image :: STRING | ||
END AS image_link, | ||
resp :data :name :: STRING AS NAME, | ||
_inserted_timestamp | ||
FROM | ||
uri_calls | ||
) | ||
SELECT | ||
resp, | ||
block_number, | ||
contract_address, | ||
registry_id, | ||
token_uri_link, | ||
trait_type, | ||
trait_value, | ||
code_uri_link, | ||
description, | ||
image_link, | ||
NAME, | ||
_inserted_timestamp, | ||
{{ dbt_utils.generate_surrogate_key( | ||
['contract_address','registry_id'] | ||
) }} AS registry_metadata_id, | ||
SYSDATE() AS inserted_timestamp, | ||
SYSDATE() AS modified_timestamp, | ||
'{{ invocation_id }}' AS _invocation_id | ||
FROM | ||
response | ||
WHERE | ||
resp :: STRING NOT ILIKE '%merkledag: not found%' | ||
AND resp :: STRING NOT ILIKE '%tuple index out of range%' | ||
AND resp :: STRING NOT ILIKE '%"error":%' |
19 changes: 19 additions & 0 deletions
19
models/silver/protocols/olas/metadata/silver_olas__registry_metadata.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
version: 2 | ||
models: | ||
- name: silver_olas__registry_metadata | ||
tests: | ||
- dbt_utils.unique_combination_of_columns: | ||
combination_of_columns: | ||
- REGISTRY_METADATA_ID | ||
columns: | ||
- name: BLOCK_NUMBER | ||
tests: | ||
- not_null | ||
- name: CONTRACT_ADDRESS | ||
tests: | ||
- not_null | ||
- dbt_expectations.expect_column_values_to_match_regex: | ||
regex: 0[xX][0-9a-fA-F]+ | ||
- name: REGISTRY_ID | ||
tests: | ||
- not_null |
35 changes: 35 additions & 0 deletions
35
models/silver/protocols/olas/metadata/silver_olas__registry_metadata_complete.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
{{ config( | ||
materialized = 'view' | ||
) }} | ||
|
||
SELECT | ||
m.name, | ||
m.description, | ||
m.registry_id, | ||
m.contract_address, | ||
CASE | ||
WHEN m.contract_address = '0xe3607b00e75f6405248323a9417ff6b39b244b50' THEN 'Service' | ||
END AS registry_type, | ||
m.trait_type, | ||
m.trait_value, | ||
m.code_uri_link, | ||
m.image_link, | ||
s.agent_ids, | ||
m.registry_metadata_id, | ||
m.inserted_timestamp, | ||
GREATEST( | ||
COALESCE( | ||
m.modified_timestamp, | ||
'1970-01-01' :: TIMESTAMP | ||
), | ||
COALESCE( | ||
s.modified_timestamp, | ||
'1970-01-01' :: TIMESTAMP | ||
) | ||
) AS modified_timestamp | ||
FROM | ||
{{ ref('silver_olas__registry_metadata') }} | ||
m | ||
LEFT JOIN {{ ref('silver_olas__getservice_reads') }} | ||
s | ||
ON m.registry_id = s.function_input |
16 changes: 16 additions & 0 deletions
16
models/silver/protocols/olas/metadata/silver_olas__registry_metadata_complete.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
version: 2 | ||
models: | ||
- name: silver_olas__registry_metadata_complete | ||
tests: | ||
- dbt_utils.unique_combination_of_columns: | ||
combination_of_columns: | ||
- REGISTRY_METADATA_ID | ||
columns: | ||
- name: CONTRACT_ADDRESS | ||
tests: | ||
- not_null | ||
- dbt_expectations.expect_column_values_to_match_regex: | ||
regex: 0[xX][0-9a-fA-F]+ | ||
- name: REGISTRY_ID | ||
tests: | ||
- not_null |
Oops, something went wrong.