Skip to content

Releases: fivetran/dbt_shopify_source

v0.8.0 dbt_shopify_source

31 Jan 20:59
3ee6cc2
Compare
Choose a tag to compare

Lots of new features ahead!! We've revamped the package to keep up-to-date with new additions to the Shopify connector and feedback from the community.

This release includes 🚨 Breaking Changes 🚨.

Documentation

  • Created the DECISIONLOG to log discussions and opinionated stances we took in designing the package (PR #45).
  • README updated for easier package use and navigation (PR #38).

Under the Hood

  • Ensured Postgres compatibility (PR #38).
  • Got rid of the shopify__using_order_adjustment, shopify__using_order_line_refund, and shopify__using_refund variables. Instead, the package will automatically create empty versions of the related models until the source refund, order_line_refund, and order_adjustment tables exist in your schema. See DECISIONLOG for more details (PR #45).
  • Adjusts the organization of the get_<table>_columns() macros (PR #39, PR #40).

Feature Updates

  • Addition of the shopify_timezone variable, which converts ALL timestamps included in the package (including _fivetran_synced) to a single target timezone in IANA Database format, ie "America/Los_Angeles" (PR #41).
  • shopify_<default_source_table_name>_identifier variables added if an individual source table has a different name than the package expects (PR #38).
  • The declaration of passthrough variables within your root dbt_project.yml has changed (but is backwards compatible). To allow for more flexibility and better tracking of passthrough columns, you will now want to define passthrough columns in the following format (PR #40):

This applies to all passthrough columns within the dbt_shopify_source package and not just the customer_pass_through_columns example. See the README for which models have passthrough columns.

vars:
  customer_pass_through_columns:
    - name: "my_field_to_include" # Required: Name of the field within the source.
      alias: "field_alias" # Optional: If you wish to alias the field within the staging model.
      transform_sql: "cast(field_alias as string)" # Optional: If you wish to define the datatype or apply a light transformation.
  • The following fields have been added to (➕) or removed from (➖) their respective staging models (PR #39, PR #40):
    • stg_shopify__order:
      • total_discounts_set
      • total_line_items_price_set
      • total_price_usd
      • total_price_set
      • total_tax_set
      • total_tip_received
      • is_deleted
      • app_id
      • checkout_id
      • client_details_user_agent
      • customer_locale
      • order_status_url
      • presentment_currency
      • is_confirmed
    • stg_shopify__customer:
      • note
      • lifetime_duration
      • currency
      • marketing_consent_state (coalescing of email_marketing_consent_state and deprecated accepts_marketing field)
      • marketing_opt_in_level (coalescing of email_marketing_consent_opt_in_level and deprecated marketing_opt_in_level field)
      • marketing_consent_updated_at (coalescing of email_marketing_consent_consent_updated_at and deprecated accepts_marketing_updated_at field)
      • accepts_marketing/has_accepted_marketing
      • accepts_marketing_updated_at
      • marketing_opt_in_level
    • stg_shopify__order_line_refund:
      • subtotal_set
      • total_tax_set
    • stg_shopify__order_line:
      • pre_tax_price_set
      • price_set
      • tax_code
      • total_discount_set
      • variant_title
      • variant_inventory_management
      • properties
      • ( ) is_requiring_shipping is renamed to is_shipping_required
    • stg_shopify__product:
      • status
    • stg_shopify__product_variant
      • old_inventory_quantity -> coalesced with inventory_quantity
      • inventory_quantity -> coalesced with old_inventory_quantity
  • The following source tables have been added to the package with respective staging models (PR #39):
    • abandoned_checkout
    • collection_product
    • collection
    • customer_tag
    • discount_code -> if the table does not exist in your schema, the package will create an empty staging model and reference that (PR #47, see DECISIONLOG)
    • fulfillment
    • inventory_item
    • inventory_level
    • location
    • metafield (#PR 49 as well)
    • order_note_attribute
    • order_shipping_line
    • order_shipping_tax_line
    • order_tag
    • order_url_tag
    • price_rule
    • product_image
    • product_tag
    • shop
    • tender_transaction
    • abandoned_checkout_discount_code
    • order_discount_code
    • tax_line
    • abandoned_checkout_shipping_line ((PR #47) as well)
    • fulfillment_event -> This is NOT included by default. To include fulfillment events (used in the shopify__daily_shop model), set the shopify_using_fulfillment_event variable to true (PR #48)

dbt_shopify_source v0.7.0

03 Jan 21:51
0294433
Compare
Choose a tag to compare

🚨 Breaking Changes 🚨:

PR #36 includes the following breaking changes:

  • Dispatch update for dbt-utils to dbt-core cross-db macros migration. Specifically {{ dbt_utils.<macro> }} have been updated to {{ dbt.<macro> }} for the below macros:
    • any_value
    • bool_or
    • cast_bool_to_text
    • concat
    • date_trunc
    • dateadd
    • datediff
    • escape_single_quotes
    • except
    • hash
    • intersect
    • last_day
    • length
    • listagg
    • position
    • replace
    • right
    • safe_cast
    • split_part
    • string_literal
    • type_bigint
    • type_float
    • type_int
    • type_numeric
    • type_string
    • type_timestamp
    • array_append
    • array_concat
    • array_construct
  • For current_timestamp and current_timestamp_in_utc macros, the dispatch AND the macro names have been updated to the below, respectively:
    • dbt.current_timestamp_backcompat
    • dbt.current_timestamp_in_utc_backcompat
  • Dependencies on fivetran/fivetran_utils have been upgraded, previously [">=0.3.0", "<0.4.0"] now [">=0.4.0", "<0.5.0"].

shopify_source 0.6.0

22 Dec 01:46
c7b95b8
Compare
Choose a tag to compare

🎉 dbt v1.0.0 Compatibility 🎉

🚨 Breaking Changes 🚨

  • Adjusts the require-dbt-version to now be within the range [">=1.0.0", "<2.0.0"]. Additionally, the package has been updated for dbt v1.0.0 compatibility. If you are using a dbt version <1.0.0, you will need to upgrade in order to leverage the latest version of the package.

    • For help upgrading your package, I recommend reviewing this GitHub repo's Release Notes on what changes have been implemented since your last upgrade.
    • For help upgrading your dbt project to dbt v1.0.0, I recommend reviewing dbt-labs upgrading to 1.0.0 docs for more details on what changes must be made.
  • Upgrades the package dependency to refer to the latest dbt_fivetran_utils. The latest dbt_fivetran_utils package also has a dependency on dbt_utils [">=0.8.0", "<0.9.0"].

    • Please note, if you are installing a version of dbt_utils in your packages.yml that is not in the range above then you will encounter a package dependency error.
  • The union_schemas and union_databases variables have been replaced with shopify_union_schemas and shopify_union_databases respectively. This allows for multiple packages with the union ability to be used and not locked to a single variable that is used across packages.

dbt_shopify_source 0.5.2

01 Dec 21:20
e262987
Compare
Choose a tag to compare

Happy Wednesday!

This release includes the following updates to the dbt_shopify_source package:

Under the Hood

Rearranged the ordering of the columns within the get_order_columns macro. This ensure the output of the models within the downstream Shopify Holistic Reporting package are easier to understand and interpret. (#29)

Ability to Disable Order Adjustment and Refunds Models

08 Sep 19:49
Compare
Choose a tag to compare

Happy Wednesday!

This release includes the following added features to the Fivetran Shopify Source dbt package:

  • Ability to disable the order_adjustment, order_line_refund, and refund staging models if you do not currently sync them by leveraging the variables highlighted within the README. PR #24

dbt 0.20.0 Compatibility

05 Aug 14:46
eda9beb
Compare
Choose a tag to compare

🎉 dbt 0.20.0 Compatibility 🎉

🚨 This is a breaking change! 🚨 dbt v0.20.0 or greater is required for this release. If you are not ready to upgrade, consider using a previous release of this package.

Additional considerations when upgrading to this package:

  • This package utilizes the latest v0.7.x release of the dbt-labls/dbt_utils package. If your project also utilizes a version of the fishtown-analytics/dbt_utils package then you will receive a duplicate package error. If this is the case you will need to consider upgrading your other packages to be compatible with this update or use a previous release of this package.
  • Similar to the above point, all previous Fivetran dbt packages utilize the fishtown-analytics/dbt_utils package and you will need to upgrade all Fivetran dbt packages to the latest dbt 0.20.0 compatibility releases in order for your packages to run without package conflicts.
  • For Databricks users this compatibility is currently only available for >=dbt 0.20.1rc1. If you want more information on upgrading your dbt-spark version, you can refer to the dbt-spark release for further details.

Fivetran Utils Dependency Update

09 Jul 11:32
e7d31b7
Compare
Choose a tag to compare

🚧 Fivetran Utils Dependency Update 🚧

This release includes the following non-breaking changes:

  • Update to the packages.yml to reference the recently released Fivetran Utils package. This is a necessary update to ensure this package is compatible with previous dbt releases before dbt v0.20.0 updates take place.

README Typo Fix

28 Jun 20:41
2cf4947
Compare
Choose a tag to compare

Happy Monday!

This release includes the following non-breaking changes:

  • Typo fix within the README to reference the correct union_schemas variable. PR #19

Union Source Data Functionality (Breaking Change)

23 Jun 15:38
Compare
Choose a tag to compare

🚨 BREAKING CHANGE 🚨 Unioning Shopify source data has been a frequent request from package users. This release incorporates just that functionality!

  • The ability to union Shopify source data using this package. This is done by utilizing the union_schema and union_databases variables. A user can add the schemas they would like to union or the databases they would like to union (must be one or the other) together and produce unioned results downstream.

Thanks so much to @DylanBaker for his stellar work on getting this functionality to work in this package! 🎉

Features Updates + custom schema (breaking change 🚨)

27 May 01:33
5ec9a1e
Compare
Choose a tag to compare

This release incorporates the following new features:

  • Databricks and Postgres compatibility
  • Custom schema integration (breaking change 🚨)
  • Addition of the transaction, refund, and order_adjustment source tables!
  • Github pages integration