Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add passthrough columns for USER + ORG and add support for updated passthrough format for TICKET #49

Merged
merged 4 commits into from
Apr 15, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,14 @@
# dbt_zendesk_source v0.11.2

[PR #49](https://github.com/fivetran/dbt_zendesk_source/pull/49) includes the following updates:

## Feature Updates
- Adds passthrough column support for `USER` and `ORGANIZATION`.
- Using the new `zendesk__user_passthrough_columns` and `zendesk__organization_passthrough_columns` variables, you can include custom columns from these source tables in their respective staging models. See [README](https://github.com/fivetran/dbt_zendesk_source?tab=readme-ov-file#add-passthrough-columns) for more details on how to configure.
- Also updated the format of the pre-existing `TICKET` passthrough column variable, `zendesk__ticket_passthrough_columns`, to align with the newly added passthrough variables delineated above.
- Previously, you could only provide a list of custom fields to be included in `stg_zendesk__ticket`. Now, you have the option to provide an `alias` and `transform_sql` clause to be applied to each field (see [README](https://github.com/fivetran/dbt_zendesk_source?tab=readme-ov-file#add-passthrough-columns) for more details).
- **Note**: the package is and will continue to be backwards compatible with the old list-format.

# dbt_zendesk_source v0.11.1

[PR #48](https://github.com/fivetran/dbt_zendesk_source/pull/48) includes the following updates:
Expand Down
24 changes: 22 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,14 +66,33 @@ vars:
```

## (Optional) Step 5: Additional configurations
<details open><summary>Collapse/Expand configurations</summary>

### Add passthrough columns
This package includes all source columns defined in the staging models. However, the `stg_zendesk__ticket` model allows for additional columns to be added using a pass-through column variable. This is extremely useful if you'd like to include custom fields to the package.
This package includes all source columns defined in the macros folder. You can add more columns from the `TICKET`, `USER`, and `ORGANIZATION` tables using our pass-through column variables, which will persist these custom fields to the `stg_zendesk__ticket`, `stg_zendesk__user`, and `stg_zendesk__organization` models, respectively.

These variables allow for the pass-through fields to be aliased (`alias`) and casted (`transform_sql`) if desired, but not required. Datatype casting is configured via a sql snippet within the `transform_sql` key. You may add the desired sql while omitting the `as field_name` at the end and your custom pass-through fields will be casted accordingly. Use the below format for declaring the respective pass-through variables:

```yml
vars:
zendesk__ticket_passthrough_columns: [account_custom_field_1, account_custom_field_2]
zendesk__ticket_passthrough_columns:
- name: "account_custom_field_1" # required
alias: "account_1" # optional
transform_sql: "cast(account_1 as string)" # optional, must reference the alias if an alias is provided (otherwise the original name)
- name: "account_custom_field_2"
transform_sql: "cast(account_custom_field_2 as string)"
- name: "account_custom_field_3"
zendesk__user_passthrough_columns:
- name: "internal_app_id_c"
alias: "app_id"
zendesk__organization_passthrough_columns:
- name: "custom_org_field_1"
```

> Note: Earlier versions of this package employed a more rudimentary format for passthrough columns, in which the user provided a list of field names to pass in, rather than a mapping. In the above `ticket` example, this would be `[account_custom_field_1, account_custom_field_2, account_custom_field_3]`.
>
> This old format will still work, as our passthrough-column macros are all backwards compatible.

### Mark Former Internal Users as Agents
If a team member leaves your organization and their internal account is deactivated, their `USER.role` will switch from `agent` or `admin` to `end-user`. This will skew historical ticket SLA metrics, as we calculate reply times and other metrics based on `agent` or `admin` activity only.

Expand Down Expand Up @@ -115,6 +134,7 @@ vars:
zendesk_group_identifier: "Group" # as an example, must include the double-quotes and correct case!
```

</details>

## (Optional) Step 6: Orchestrate your models with Fivetran Transformations for dbt Core™
<details><summary>Expand to view details</summary>
Expand Down
6 changes: 5 additions & 1 deletion dbt_project.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
config-version: 2
name: 'zendesk_source'
version: '0.11.1'
version: '0.11.2'
require-dbt-version: [">=1.3.0", "<2.0.0"]
models:
zendesk_source:
Expand Down Expand Up @@ -28,3 +28,7 @@ vars:
user: "{{ source('zendesk', 'user') }}"
time_zone: "{{ source('zendesk', 'time_zone') }}"
daylight_time: "{{ source('zendesk', 'daylight_time') }}"

zendesk__ticket_passthrough_columns: []
zendesk__user_passthrough_columns: []
zendesk__organization_passthrough_columns: []
2 changes: 1 addition & 1 deletion docs/catalog.json

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion docs/manifest.json

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion docs/run_results.json

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion integration_tests/dbt_project.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
config-version: 2

name: 'zendesk_source_integration_tests'
version: '0.11.1'
version: '0.11.2'

profile: 'integration_tests'

Expand Down
2 changes: 2 additions & 0 deletions macros/get_organization_columns.sql
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@
{"name": "url", "datatype": dbt.type_string()}
] %}

{{ fivetran_utils.add_pass_through_columns(columns, var('zendesk__organization_passthrough_columns')) }}

{{ return(columns) }}

{% endmacro %}
2 changes: 2 additions & 0 deletions macros/get_ticket_columns.sql
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,8 @@
{"name": "via_source_to_name", "datatype": dbt.type_int()}
] %}

{{ fivetran_utils.add_pass_through_columns(columns, var('zendesk__ticket_passthrough_columns')) }}

{{ return(columns) }}

{% endmacro %}
2 changes: 2 additions & 0 deletions macros/get_user_columns.sql
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@
{"name": "verified", "datatype": "boolean"}
] %}

{{ fivetran_utils.add_pass_through_columns(columns, var('zendesk__user_passthrough_columns')) }}

{{ return(columns) }}

{% endmacro %}
2 changes: 2 additions & 0 deletions models/stg_zendesk__organization.sql
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@ final as (
name,
external_id

{{ fivetran_utils.fill_pass_through_columns('zendesk__organization_passthrough_columns') }}

from fields
)

Expand Down
14 changes: 1 addition & 13 deletions models/stg_zendesk__ticket.sql
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,6 @@ fields as (
staging_columns=get_ticket_columns()
)
}}

--The below script allows for pass through columns.
{% if var('zendesk__ticket_passthrough_columns',[]) != [] %}
,
{{ var('zendesk__ticket_passthrough_columns') | join (", ") }}

{% endif %}

from base
),
Expand Down Expand Up @@ -64,12 +57,7 @@ final as (
via_source_to_address as source_to_address,
via_source_to_name as source_to_name

--The below script allows for pass through columns.
{% if var('zendesk__ticket_passthrough_columns',[]) != [] %}
,
{{ var('zendesk__ticket_passthrough_columns') | join (", ") }}

{% endif %}
{{ fivetran_utils.fill_pass_through_columns('zendesk__ticket_passthrough_columns') }}

from fields
)
Expand Down
3 changes: 3 additions & 0 deletions models/stg_zendesk__user.sql
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,9 @@ final as (
locale,
active as is_active,
suspended as is_suspended

{{ fivetran_utils.fill_pass_through_columns('zendesk__user_passthrough_columns') }}

from fields
)

Expand Down