-
Notifications
You must be signed in to change notification settings - Fork 29
/
int_zendesk__sla_policy_applied.sql
58 lines (47 loc) · 2.68 KB
/
int_zendesk__sla_policy_applied.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
-- step 1, figure out when sla was applied to tickets
-- more on SLA policies here: https://support.zendesk.com/hc/en-us/articles/204770038-Defining-and-using-SLA-policies-Professional-and-Enterprise-
-- SLA policies are calculated for next_reply_time, first_reply_time, agent_work_time, requester_wait_time. If you're company uses other SLA metrics, and would like this
-- package to support those, please reach out to the Fivetran team on Slack.
with ticket_field_history as (
select *
from {{ ref('int_zendesk__updates') }}
), sla_policy_name as (
select
*
from {{ ref('int_zendesk__updates') }}
where field_name = ('sla_policy')
), ticket as (
select *
from {{ ref('int_zendesk__ticket_aggregates') }}
), sla_policy_applied as (
select
ticket_field_history.source_relation,
ticket_field_history.ticket_id,
ticket.created_at as ticket_created_at,
ticket_field_history.valid_starting_at,
ticket.status as ticket_current_status,
ticket_field_history.field_name as metric,
case when ticket_field_history.field_name = 'first_reply_time' then row_number() over (partition by ticket_field_history.source_relation, ticket_field_history.ticket_id, ticket_field_history.field_name order by ticket_field_history.valid_starting_at desc) else 1 end as latest_sla,
case when ticket_field_history.field_name = 'first_reply_time' then ticket.created_at else ticket_field_history.valid_starting_at end as sla_applied_at,
cast({{ fivetran_utils.json_parse('ticket_field_history.value', ['minutes']) }} as {{ dbt.type_int() }} ) as target,
{{ fivetran_utils.json_parse('ticket_field_history.value', ['in_business_hours']) }} = 'true' as in_business_hours
from ticket_field_history
join ticket
on ticket.ticket_id = ticket_field_history.ticket_id
and ticket.source_relation = ticket_field_history.source_relation
where ticket_field_history.value is not null
and ticket_field_history.field_name in ('next_reply_time', 'first_reply_time', 'agent_work_time', 'requester_wait_time')
), final as (
select
sla_policy_applied.*,
sla_policy_name.value as sla_policy_name
from sla_policy_applied
left join sla_policy_name
on sla_policy_name.ticket_id = sla_policy_applied.ticket_id
and sla_policy_name.source_relation = sla_policy_applied.source_relation
and {{ dbt.date_trunc("second", "sla_policy_applied.valid_starting_at") }} >= {{ dbt.date_trunc("second", "sla_policy_name.valid_starting_at") }}
and {{ dbt.date_trunc("second", "sla_policy_applied.valid_starting_at") }} < coalesce({{ dbt.date_trunc("second", "sla_policy_name.valid_ending_at") }}, {{ dbt.current_timestamp() }})
where sla_policy_applied.latest_sla = 1
)
select *
from final