Releases: fivetran/dbt_fivetran_log
v1.5.0 dbt_fivetran_log
PR #114 includes the following updates:
Breaking Changes
⚠️ Since the following changes are breaking, we recommend running a--full-refresh
after upgrading to this version.
- For Bigquery and Databricks destinations, updated the
partition_by
config to coordinate with the filter used in the incremental logic. - For Snowflake destinations, added a
cluster_by
config for performance.
Feature Updates
- Updated incremental logic for
fivetran_platform__audit_table
so that it looks back 7 days to catch any late arriving records. - Updated JSON parsing logic in the following models to prevent run failures when incoming JSON-like strings are invalid.
fivetran_platform__audit_table
fivetran_platform__audit_user_activity
fivetran_platform__connector_daily_events
fivetran_platform__connector_status
fivetran_platform__schema_changelog
- Updated
fivetran_platform__connector_status
to parse only a subset of themessage_data
field to improve compute.
Under The Hood
- Added macros:
fivetran_log_json_parse
to handle the updated JSON parsing.fivetran_log_lookback
for use infivetran_platform__audit_table
.
- Updated seeds to test handling of invalid JSON strings.
Full Changelog: v1.4.3...v1.5.0
v1.4.3 dbt_fivetran_log
PR #112 includes the following updates:
Feature Updates
- Updated logic for
connector_health
dimension infivetran_platform__connector_status
to showdeleted
for connectors that had been removed. Previously the connector would report the last known status before deletion, which is inaccurate based on the definition of this measure. - Brought in the
is_deleted
dimension (based on the_fivetran_deleted
value) tostg_fivetran__platform__connector
to capture connectors that are deleted in the downstreamfivetran_platform__connector_status
model.
Under The Hood
- Renamed
get_brand_columns
macro file toget_connector_columns
to maintain consistency with the actual macro function within the file, and theconnector
source that the macro is drawing columns from.
Full Changelog: v1.4.2...v1.4.3
v1.4.2 dbt_fivetran_log
PR #109 includes the following updates:
Bug Fixes
- Adjusted the
stg_fivetran_platform__credits_used
andstg_fivetran_platform__usage_cost
models to return empty tables (via alimit 0
) if the respectivefivetran_platform__credits_pricing
and/orfivetran_platform__usage_pricing
variables are disabled. This is to avoid Postgres data type errors if those tables are null.
Under the Hood
- Included an additional test case within the integration tests where the
fivetran_platform__credits_pricing
variable is set to false and thefivetran_platform__usage_pricing
variable is set to true in order to effectively test this scenario. - Updated seed files to ensure downstream models properly populate into
fivetran_platform__usage_mar_destination_history
.
Full Changelog: v1.4.1...v1.4.2
v1.4.1 dbt_fivetran_log
PR #107 includes the following updates:
Bug Fixes
- Adjusted the
fivetran_platform__audit_user_activity
model to parse themessage_data
json field to obtain the actor_email information only if the field containsactor
.- This ensures the JSON parsing is only happening on the fields that are relevant. This will help reduce compute and avoid potential parsing errors from malformed JSON objects.
Under the Hood
- Included auto-releaser GitHub Actions workflow to automate future releases.
- Updated the maintainer PR template to resemble the most up to date format.
- Included a
quickstart.yml
file to allow for automated Quickstart data model deployments.
Full Changelog: v1.4.0...v1.4.1
v1.4.0 dbt_fivetran_log
Feature Updates
- This release introduces compatibility with SQL Server 🥳 🎆 🍾 (PR #101)
Bug Fixes
- Adjusts the uniqueness test on the recently introduced
fivetran_platform__audit_user_activity
model to test onlog_id
andoccurred_at
(PR #102).- Previously, the
log_id
was erroneously considered the primary key of this model.
- Previously, the
Under the Hood
- Removed
order by
from the finalselect
statement in each model. This was done to reduce compute costs from the models (PR #101). - Converted all
group by
's to explicitly reference the names of columns we are grouping by, instead of grouping by column number. This was necessary for SQL Server compatibility, as implicit groupings are not supported (PR #101).
Full Changelog: v1.3.0...v1.4.0
v1.3.0 dbt_fivetran_log
🚨 Breaking Changes 🚨
- Deprecated the
transformation
andtrigger_table
source tables and any downstream transforms. These tables only housed information on Fivetran Basic SQL Transformations, which were sunset last year (PR #96).- The entire
fivetran_platform__transformation_status
end model has therefore been removed. - As they are now obsolete, the
fivetran_platform_using_transformations
andfivetran_platform_using_triggers
variables have been removed.
- The entire
👶🏽 New Model Alert 👶🏽
- We have added a new model,
fivetran_platform__audit_user_activity
(PR #98):- Each record represents a user-triggered action in your Fivetran instance. This model is intended for audit-trail purposes, as it can be very helpful when trying to trace a user action to a log event such as a schema change, sync frequency update, manual update, broken connection, etc.
- This model builds off of this sample query from Fivetran's docs.
🪲 Bug Fixes 🪲
- Tightened incremental logic in
fivetran_platform__audit_table
, which was seeing duplicates on incremental runs (PR #97).- If you are seeing uniqueness test failures on the
unique_table_sync_key
field, please run a full refresh before upgrading to this version of the package.
- If you are seeing uniqueness test failures on the
🛠 Under the Hood 🛠
- Added a dependency on the
dbt_date
package (PR #98):
- package: calogica/dbt_date
version: [">=0.9.0", "<1.0.0"]
Full Changelog: v1.2.0...v1.3.0
v1.2.0 dbt_fivetran_log
PR #92 includes the following updates:
Bug Fixes
- The
unique_table_sync_key
surrogate key which is created within thefivetran_platform__audit_table
has been updated to also be comprised of theschema_name
in addition to theconnector_id
,destination_id
,table_name
,write_to_table_start
fields. This update will also ensure the uniqueness test on this record is accurately testing the true grain of the model.- 🚨 Please be aware that as the
fivetran_platform__audit_table
model is an incremental model a--full-refresh
will be needed following the package upgrade in order for this change to properly be applied to all records in the end model. 🚨
- 🚨 Please be aware that as the
Contributors
Full Changelog: v1.1.0...v1.2.0
v1.1.0 dbt_fivetran_log
PR #87 includes the following updates:
🚨 Feature Updates (Breaking Change) 🚨
The below change was made to an incremental model. As such, a dbt run --full-refresh
will be required following an upgrade to capture the new column.
- Added
schema_name
to thefivetran_platform__audit_table
end model. This schema name field is captured from themessage_data
JSON within thelog
source table. In cases where theschema_name
is not provided a coalesce was added to replicate theconnector_name
as theschema_name
.
Note: This may change the row count of your
fivetran_platform__audit_table
model. However, this new row count is more correct, as it more accurately captures records from database connectors, which can write to multiple schemas.
Documentation Updates
- Fixed links in the README models section to properly redirect to the dbt hosted docs for the relevant models.
Full Changelog: v1.0.1...v1.1.0
v1.0.1 dbt_fivetran_log
PR #85 includes the following update:
Bugfix 🐞
- Update staging models CTE names to current standard used in our other packages (the base, fields, final approach) to avoid potential circular references
Full Changelog: v1.0.0...v1.0.1
v1.0.0 dbt_fivetran_log
The Fivetran Log connector has been renamed to the "Fivetran Platform" connector. To align with this name change, this package is largely being renamed from fivetran_log
to fivetran_platform
. This is a very breaking change! 🚨 🚨 🚨 🚨
Bottom Line: What you need to update and/or know:
- If you are setting any variables for this package in your
dbt_project.yml
, update the name of the prefix of the variable(s) fromfivetran_log_*
tofivetran_platform_*
. The default values for variables have not changed. - Similarly, any references to package models will need to be updated. The prefix of package models has been updated from
fivetran_log__*
tofivetran_platform__*
. - If you are overriding the
fivetran_log
source, you will need to update theoverrides
property to match the newsource
name (fivetran_platform
). - Run a full refresh, as we have updated the incremental strategies across warehouses.
- The default build schema suffixes have been changed from
_stg_fivetran_log
and_fivetran_log
to_stg_fivetran_platform
and_fivetran_platform
respectively. We recommend dropping the old schemas.
Note: Things that are NOT changing in the package:
- The name of the Github repository will not be changed. It will remain
dbt_fivetran_log
- The package's project name will remain
fivetran_log
. You will not need to update yourpackages.yml
reference. - The default source schema will remain
fivetran_log
. The name of the source schema variable has changed though (fivetran_log_schema
->fivetran_platform_schema
).
See details below!
PR #81 introduced the following changes (some unrelated to the connector name change):
🚨 Breaking Changes 🚨
- Updated the prefixes of each model from
fivetran_log_*
orstg_fivetran_log_*
tofivetran_platform_*
andstg_fivetran_platform_*
, respectively.
Original model name | New model name |
---|---|
fivetran_log__audit_table | fivetran_platform__audit_table |
fivetran_log__connector_daily_events | fivetran_platform__connector_daily_events |
fivetran_log__connector_status | fivetran_platform__connector_status |
fivetran_log__mar_table_history | fivetran_platform__mar_table_history |
fivetran_log__schema_changelog | fivetran_platform__schema_changelog |
fivetran_log__transformation_status | fivetran_platform__transformation_status |
fivetran_log__usage_mar_destination_history | fivetran_platform__usage_mar_destination_history |
stg_fivetran_log__account | stg_fivetran_platform__account |
stg_fivetran_log__connector | stg_fivetran_platform__connector |
stg_fivetran_log__credits_used | stg_fivetran_platform__credits_used |
stg_fivetran_log__destination_membership | stg_fivetran_platform__destination_membership |
stg_fivetran_log__destination | stg_fivetran_platform__destination |
stg_fivetran_log__incremental_mar | stg_fivetran_platform__incremental_mar |
stg_fivetran_log__log | stg_fivetran_platform__log |
stg_fivetran_log__transformation | stg_fivetran_platform__transformation |
stg_fivetran_log__trigger_table | stg_fivetran_platform__trigger_table |
stg_fivetran_log__usage_cost | stg_fivetran_platform__usage_cost |
stg_fivetran_log__user | stg_fivetran_platform__user |
- Updated the prefix of all package variables from
fivetran_log_*
tofivetran_platform_*
.
Original variable name | New variable name | Default value (consistent) |
---|---|---|
fivetran_log_schema | fivetran_platform_schema | fivetran_log |
fivetran_log_database | fivetran_platform_database | target.database |
fivetran_log__usage_pricing | fivetran_platform__usage_pricing | Dynamically checks the source at runtime to set as either true or false . May be overridden using this variable if desired. |
fivetran_log__credits_pricing | fivetran_platform__credits_pricing | Dynamically checks the source at runtime to set as either true or false . May be overridden using this variable if desired |
fivetran_log_using_sync_alert_messages | fivetran_platform_using_sync_alert_messages | True |
fivetran_log_using_transformations | fivetran_platform_using_transformations | True |
fivetran_log_using_triggers | fivetran_platform_using_triggers | True |
fivetran_log_using_destination_membership | fivetran_platform_using_destination_membership | True |
fivetran_log_using_user | fivetran_platform_using_user | True |
fivetran_log_[default_table_name]_identifier | fivetran_platform_[default_table_name]_identifier | Default table name (ie 'connector' for fivetran_platform_connector_identifier ) |
- Updated the default build schema suffixes of package models from
_stg_fivetran_log
and_fivetran_log
to_stg_fivetran_platform
and_fivetran_platform
respectively.
We recommend dropping the old schemas to eradicate the stale pre-name-change models from your destintation.
- Updated the name of the package's source from
fivetran_log
tofivetran_platform
. - Updated the name of the packages' schema files:
src_fivetran_log.yml
->src_fivetran_platform.yml
stg_fivetran_log.yml
->stg_fivetran_platform.yml
fivetran_log.yml
->fivetran_platform.yml
- Updated the freshness tests on the
fivetran_platform
source to be less stringent and more realistic. The following source tables have had their default fresness tests removed, as they will not necessarily update frequently:connector
account
destination
destination_membership
user
- Updated the incremental strategy of the audit table model for BigQuery and Databricks users from
merge
to the more consistentinsert_overwrite
method. We have also updated thefile_format
toparquet
and added a partition on a newsync_start_day
field for Databricks. This field is merely a truncated version ofsync_start
.- Run a full refresh to capture these new changes. We recommend running a full refresh every so often regardless. See README for more details.
- The
account_membership
source table (and any of its transformations) has been deprecated. Fivetran deprecated this table from the connector in June 2023.
Considerations
⚠️ If you are overriding thefivetran_log
source, you will need to update theoverrides
property to match the newsource
name (fivetran_platform
).
Under the Hood
- Added documentation for fields missing yml entries.
- Incorporated the new
fivetran_utils.drop_schemas_automation
macro into the end of each Buildkite integration test job (PR #80). - Updated the pull request templates (PR #80).
Full Changelog: v0.7.4...v1.0.0