PR #17 includes the following updates:
- Enabled
servicenow__user_aggregated
andservicenow__user_enhanced
by default by changing the defaultservicenow__using_roles
value to true. - Staging and base models now also enabled by default include:
stg_servicenow__sys_user_grmember
stg_servicenow__sys_user_has_role
stg_servicenow__sys_user_role
stg_servicenow__sys_user_grmember_base
stg_servicenow__sys_user_has_role_base
stg_servicenow__sys_user_role_base
- Because this change will introduce new end model tables to users because they were initially disabled by default and changes the default behavior of a variable, we've classified this as a breaking change.
- Quickstart users will be able to handle disabling of these tables by utilizing the Quickstart data model tab within your ServiceNow connection, and choose to un-sync the tables required for these models.
- Non-Quickstart users who do not have these source tables will need to define the variable in their
dbt_project.yml
. See the README for more instructions.
- Updated the variable configuration section of the README since
servicenow__using_roles
is now set to true by default. - Moved badges at top of the README below the H1 header to be consistent with popular README formats.
- Changed Buildkite scripts to run models when
servicenow__using_roles
is set to False (since it's now True by default on all models). - Updated validation tests to account for the new
servicenow__using_roles
variable configuration.
PR #10 includes the following updates:
- The following fields were removed from the
servicenow__task_enhanced
model asproblem_first_reported_by_task_value
was incorrectly assumed to have correspondingsys_user
values, but in actuality is related to the task table and therefore have no user fields.problem_reporter_email
problem_reporter_manager_value
problem_reporter_department_value
problem_reporter_name
problem_reporter_roles
-
The following fields were added to the
servicenow__incident_enhanced
model to add relevant display names to thecaller_id_value
.caller_email
caller_manager_value
caller_department_value
caller_name
caller_roles
-
The following fields were added to the
servicenow__user_enhanced
model to add relevant display names to thecompany_value
andmanager_value
.company_name
manager_name
-
The following label fields were added to respective choice fields in order to bring the display value (
dv
), or human-readable text available in the ServiceNow UI, displayed for each choice option:dv_priority_label
dv_impact_label
dv_urgency_label
dv_task_state_label
dv_problem_state_label
dv_change_request_type_label
dv_change_request_phase_state_label
dv_change_request_risk_label
dv_incident_category_label
dv_incident_subcategory_label
dv_incident_severity_label
dv_incident_state_label
dv_business_impact_label
-
Certain choice fields have labels that can depend on the
dependent_value
field in thesys_choice
table. This dependency typically arises when the same choice field can have different labels based on the context in which it is used. Therefore some elements fromsys_choice
are also joined in on the additionaldependent_value
field. For example, here is a common example wheredependent_value
might influence the label:incident_category
andincident_subcategory
: These fields often depend on each other. For instance, if theincident_category
is "Software," theincident_subcategory
might have different options compared to when the category is "Hardware." Thedependent_value
in this case could represent the incident_category and influence the incident_subcategory labels.- For more information about the logic used to attach labels to choice fields, refer to the DECISIONLOG where a section has been added (titled Methodology for Adding Labels for Choice Fields).
- To include labels, we used a new source table
sys_choice
. This is reflected upstream, in the newly addedstg_servicenow__sys_choice
andstg_servicenow__sys_choice_base
.
- The following fields, which previously only existed in intermediate CTEs, have been persisted through to the
servicenow__user_aggregated
andservicenow__user_enhanced
models to add more user metadata:count_distinct_sys_user_group_ids
count_distinct_sys_user_role_ids
count_distinct_sys_user_role_names
count_distinct_included_roles
count_distinct_sys_user_group_roles
- Additionally, we've realized the way these fields were previously aggregated could unintentionally also include blank values that were not-null, so we have updated the logic accordingly.
- Added explicit casts to timestamp fields, as well as string casts to choice fields in order to join them later downstream on
sys_choice.element
. - Added consistency and integrity validation tests within integration_tests folder for all current end models.
PR #8 includes the following updates:
- Adds the following new models:
Model | Description |
---|---|
servicenow__problem_enhanced | Each record represents a problem with additional information about users who have interacted with it, pertinent task data, and relevant timestamps. |
servicenow__incident_enhanced | Each record represents an incident with additional information about users who have interacted with it and relevant timestamps. |
servicenow__change_request_enhanced | Each record represents a change request with additional information about users who have interacted with it, pertinent task data, and relevant timestamps. |
servicenow__user_aggregated | Each record represents a user with their associated groups and roles. |
servicenow__user_enhanced | Each record represents a user with their associated groups and roles, in addition to additional user info from the sys_user table. |
- In addition, adds the following upstream tables:
stg_servicenow__sys_user_grmember_base
,stg_servicenow__sys_user_has_role_base
,stg_servicenow__sys_user_role_base
- Records where
_fivetran_deleted
is marked true have been removed.
- Updates field names upstream to specify what type of entity it pertains to (example: incident*)
- Introduces the
servicenow__using_roles
to enable the user role/group-based tables, which are disabled by default.
PR #7 includes the following updates:
- Documents the DECISIONLOG in the README and moves the DECISIONLOG out of the
/models
folder, so that customers will be able to easily find it as a resource.
This is the initial release of the ServiceNow dbt package!
This package models ServiceNow data from Fivetran's connector. It uses data in the format described by this ERD.
The main focus of the package is to transform the core object tables into analytics-ready models, including:
-
Materializes ServiceNow staging and output models which leverage data in the format described by this ERD.
-
The staging tables clean, test, and prepare your ServiceNow data from Fivetran's connector for analysis by doing the following:
- Renames fields for consistency and standardization. For example, primary keys
sys_id
are renamed to<table_name>_id
. - Adds column-level testing where applicable. For example, all primary keys are tested for uniqueness and non-null values.
- Generates a comprehensive data dictionary of your ServiceNow data through the dbt docs site.
- Renames fields for consistency and standardization. For example, primary keys
-
The output models are focused around task Management.
- Summarizes task, problem, change, incident, and change request data by varying grains including last updated day, status, priority, impact, and urgency.
- Enhances each task record with additional information about its associated problem, incident, or change request. Finally, it contains user information for who opened, started, updated, reported, fixed, closed, requested, reported, or confirmed the task.
For more information, refer to the README