Smartico DWH \ CRM views

This page is describing dimensional and fact tables related to the CRM module

Dimensional tables

dwh_ext_xxx.dm_activity_type

List of possible "activities" that can be used to build a Flow for the scheduled & real-time campaigns. There are activities like "Send SMS", "Send Mail", "Give Bonus", "Stop campaign" etc.

There are essential activities that exist in any campaign, like

  • Journey start (1) - represents the fact that the campaign started

  • Journey stopped (2) - represents the stop of the campaign

  • Journey Converted (3) - represents the fact that the campaign was converted

Table structure:

Column
Type
Note

activity_type_id

int64

activity_name

string

dwh_ext_xxx.dm_automation_rule

The list of automation rules. Includes both real-time and scheduled.

Table structure:

Column
Type
Note

rule_id

int64

unique ID of rule

rule_name

string

Name of rule

rule_type_id

int64

1 - realtime 2 - scheduled

2 - EVERY_TIME_CONDITION_MET

3 - STOP_AND_START

is_active

boolean

Indicator if rule is active or archived/disabled

create_by

int64

ID of backoffice user that created entity

bo_user_email

string

Email of backoffice user that created entity

dwh_ext_xxx.dm_audience

The list of campaigns. Includes both real-time and scheduled.

Table structure:

Column
Type
Note

audience_id

int64

audience_name

string

entry_mode_id

int64

0 - ONCE_IN_A_LIFE 1 - ONCE_IN_AN_OPEN_JOURNEY

2 - EVERY_TIME_CONDITION_MET

3 - STOP_AND_START

audience_status_id

int64

1 - Draft 2 - Active 3 - Paused 4 - Disabled 5 - Archived 6 - Executed (for Scheduled only)

audience_exec_type_id

int64

1 - Realtime campaign of Marketing category 2 - Realtime campaign of Operational category 3 - Scheduled campaign of Marketing category 4 - Scheduled campaign of Operational category

category_id

int64

1 - Marketing campaign 2 - Operational campaign

segment_id

int64

ID of the segment, targeted by the campaign

create_by

int64

ID of backoffice user that created entity

bo_user_email

string

Email of backoffice user that created entity

dwh_ext_xxx.dm_funnel_marker

This table defines specific markers within a campaign funnel, allowing for detailed tracking of user progression. It connects activities within an audience's journey to custom-defined funnel steps.

Table structure:

Column
Type
Note

create_date

timestamp

Create date of the marker

update_date

timestamp

Last update date of the marker

audience_activity_id

int64

The ID of the audience activity to which the funnel marker is associated. Provides for direct connection to the j_engagements table on the activity_id.

funnel_marker

string

A string representing the specific marker within the funnel (e.g., "Made Deposit", "Played a game," "Received SMS ").

Here's a query that reveals the number of users who reached each funnel marker in different campaigns over the past 7 days:

SELECT
    A.audience_name,
    F.funnel_marker,
    COUNT(DISTINCT E.user_id) AS user_count
FROM
    dwh_ext_XXX.j_engagements AS E
INNER JOIN
    dwh_ext_XXX.dm_funnel_marker AS F ON E.activity_id = F.audience_activity_id
INNER JOIN
    dwh_ext_XXX.dm_audience AS A ON E.root_audience_id = A.audience_id
WHERE
    E.create_date >= TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL 7 DAY)
GROUP BY
    A.audience_name, F.funnel_marker
ORDER BY
    A.audience_name, F.funnel_marker

dwh_ext_xxx.dm_resource

Communication resources (templates) of all types, e.g. SMS, popups, emails, etc.

Note that the list includes both - main resources and variations of the main resources

Table structure:

Column
Type
Note

resource_id

int64

Unique ID of resource

resource_parent_id

int64

ID of parent resource, in case current one is variation

resource_name

string

Name of resource in the backoffice

resource_subject

string

Subject line for Mail, Push, Inbox For SMS will contain a full body of SMS For Popups and IVR will be null, as these resource types don't have a concept close to the 'subject'. Note that string can contain tags that are replaced during the actual building of the resource for specific user

resource_type_id

int64

1 - Mail 2 - Popup 3 - SMS 4 - Push 5 - Inbox 9 - IVR

create_by

int64

ID of backoffice user that created entity

bo_user_email

string

Email of backoffice user that created entity

dwh_ext_xxx.dm_segment

The table contains information about segment's names, types, status and the times of creation and last update.

If you are looking how to get list of users that belongs to specific segment, please check Export segment article.

In the dm_segment table you can use enable_dwh_export column to see which of the segments are market as available for exporting

Column
Type
Note

segment_id

int64

ID of the segment

create_date

timestamp

Date and time when the segment was created

update_date

timestamp

Date and time when the segment was last updated

segment_name

string

Name of the segment

segment_status_id

int64

Status of the segment: 1 - Active, 2 - Archived

segment_type_id

int64

Type of segment: 1 - State based, 2 - Imported from CSV, 3 - Deprecated, 4 - Behavioural

create_by

int64

ID of backoffice user that created entity

bo_user_email

string

Email of backoffice user that created entity

enable_dwh_export

bool

Indication that users of segment can be exported from DWH

Example of query that returns list of the active segments with their descriptions and counts the number of active campaigns that the segment is currently used in.

SELECT 
    s.segment_name, 
    s.create_date, 
    s.update_date, 
    s.segment_type_id,
    CASE 
        WHEN s.segment_type_id = 1 THEN 'State based'
        WHEN s.segment_type_id = 2 THEN 'Imported from CSV'
        WHEN s.segment_type_id = 3 THEN 'Deprecated'
        WHEN s.segment_type_id = 4 THEN 'Behavioral'
        ELSE 'Unknown'
    END AS segment_type_description,
    COUNT(DISTINCT a.audience_id) AS active_campaign_count
FROM 
    dwh_ext_XXX.dm_segment AS s
JOIN 
    dwh_ext_XXX.dm_audience AS a
ON 
    s.segment_id = a.segment_id
WHERE 
    s.segment_status_id = 1  -- Active segments
    AND a.audience_status_id = 1  -- 1 indicates active campaigns
GROUP BY 
    s.segment_name, 
    s.create_date, 
    s.update_date, 
    s.segment_type_id;

dwh_ext_xxx.dm_providers_sms

List of all sms sent with their label, id, provider name and type, and create and update times.

Column
Type
Note

create_date

timestamp

Time when this communication provider is defined

update_date

timestamp

Time when this communication provider is last updated

id

int64

ID of the communication provider

provider_name

string

Name of the exact provider

provider_type

string

Name of the overall service provider

dwh_ext_xxx.dm_providers_mail

List of all emails sent with their label, id, provider name and type, and create and update times.

Column
Type
Note

create_date

timestamp

Time when this communication provider is defined

update_date

timestamp

Time when this communication provider is last updated

id

int64

ID of the communication provider

provider_name

string

Name of the exact provider

provider_type

string

Name of the overall service provider

dwh_ext_xxx.dm_bonus_template

List of all bonus templates with their label, id, type and name.

Column
Type
Note

label_id

int64

The id of the label to which this bonus templated belongs

label_bonus_template_id

int64

The id of the bonus template for the specified label

product_bonus_type_id

int64

Id that indicates the bonus type

public_name

string

Bonus template name

dwh_ext_xxx.dm_tag

List of tags (or keywords) that are associated with different CRM and gamification entities.

This table should be used in connection with dm_tag_entity

Column
Type
Note

tag_id

int64

PK

tag_name

string

The name of tag/keyword

is_deleted

bool

Indicates if tag is not in use anymore (doesn't have any related entities)

dwh_ext_xxx.dm_tag_entity

Relation between tags defined in dm_tag and entities like campaigns (dm_audience), automation rules (dm_automation_rule) and others.

Column
Type
Note

tag_id

int64

PK

entity_id

int64

ID of entity in the related table, e.g. dm_audience

entity_type_id

int64

Type of entity as: 1 - Campaign 2 - Segment 7 - Mission/Badge 10 - Bonus template 11 - Popup 12 - Push 13 - Email 14 - SMS 15 - Inbox 16 - Shop item 26 - Tournament 110 - Mini game 112 - Automation rule

is_deleted

bool

Indicates if relation is deleted

dwh_ext_xxx.dm_j_formula

Definitions of formulas for Dynamic Rewards

Column
Type
Note

formula_id

INT64

Unique identifier for the formula

label_id

INT64

Label identifier for the formula

formula_name

STRING

Name of the formula

create_by

INT64

User who created the formula

create_date

TIMESTAMP

Date and time when the formula was created

update_date

TIMESTAMP

Date and time when the formula was last updated

formula_result_type_id

INT64

Type of the formula result: BONUS_AMOUNT = 1, BONUS_TEMPLATE = 2, POINTS = 4,

bonus_template_id

INT64

For ID of Bonus template, in case result type is BONUS_TEMPLATE (2)

auto_approve

BOOL

Flag indicating if the results of formula are automatically approved as soon as calculations are done

is_enabled

BOOL

Flag indicating if the formula is enabled

approve_amount_below

FLOAT64

For result type BONUS_AMOUNT (1) and POINTS (4), the amount below which the bonus is approved automatically

round_to_decimals

INT64

For result type BONUS_AMOUNT (1) and POINTS (4), the number of decimals to round the result to

min_allowed_bonus_amount

FLOAT64

For result type BONUS_AMOUNT (1) and POINTS (4), bonuses with amounts lower than defined will be treated as invalid and won’t be issued

max_allowed_bonus_amount

FLOAT64

For result type BONUS_AMOUNT (1) and POINTS (4), bonuses will be limited to a specified amount. If the calculated bonus exceeds this limit, only the capped amount will be issued

Fact tables

Communication & Campaigns (engagements) fact tables and relation between them

dwh_ext_xxx.j_av

Includes all the attribution value data. You can read more about attribute value here

Partitioned by: event_date

Data availability: last 1080 days by event_date

Primary key: event_id, root_engagement_id, engagement_id, kpi_impact_id, resource_id (composite key)

Note: the data can mutate over the time and depends if the deposit events are delivered with delay. We recommend to reload last 3 days of data on every day ETL job.

Column
Type
Note

id (deprecated)

int64

The incremental id of the calculation fact. Important: this column is not populated anymore. See the note above regarding primary key

event_date

timestamp

The date when the attribution event (deposit) happened

resource_id

int64

FK: dm_resource,

main resource that was used for the communication

audience_id

int64

FK: dm_audience,

the campaign that triggered communication

value

numeric

The attribution amount in the label base currency that resource+campaign generated.

raw_value

numeric

The raw deposit amount in the original deposit currency

converted_value

numeric

The deposit amount converted to the label base currency

event_id

int64

The id of the attribution event (deposit) on smartico side

engagement_id

int64

Reference to the j_engagements, represents the point in the Campaign/Flow from where the communication was triggered

root_engagement_id

int64

Reference to the j_engagements, represents the "root" point in the Campaign/Flow from where the communication was triggered

kpi_impact_id

int64

The id of the attribution value impact 1 - Because of resource delivery

2 - Because the user has an impression on the resource

3 - Because the user has interaction with the resource (click) 4 - Indirect impact, when nothing from above happened

default_currency

string

The base currency of the label

user_id

int64

The user id of the user who made the deposit

calculated_ts

timestamp

Timestamp when the calculation happened

Example of query that returns attribute value per campaign (audience_id)

SELECT  audience_id, sum(value) as value
FROM dwh_ext_xxx.j_av
WHERE event_date >= TIMESTAMP("2024-07-01")
group by audience_id

Example of query that returns conversion of specific user per campaign, including the time of conversion

with x as (
  select audience_id, event_date, sum(value) as av, 
  from dwh_ext_xxx.j_av
  where user_id = 69726604
  group by audience_id, event_date
)
select a.audience_id, a.audience_name, x.av, x.event_date
from x
inner join dwh_ext_xxx.dm_audience a on x.audience_id = a.audience_id
order by x.event_date desc

dwh_ext_xxx.j_communication

This includes all communications sent to the end-user and all possible outcomes (fact_type_id) of these communications, like failure of delivery, impressions, clicks, etc.

Ideas to understand communications concept

  • the communication is always triggered by some "activity" from the campaign. This activity is referenced by engagement_id or engagement_uid. Such "activity" is part of the campaign, where the starting point of the campaign (the fact that the user entered into the campaign) is presented by the root_engagement_uuid & root_engagement_create_date. The campaign definition itself if presented by root_audience_id

  • The first fact that happens for communication is CREATE, after that, it is usually either SENT and DELIVERED or FAILED. It can be later seen by the end-user (IMPRESSION) and CLICKED. Users can also OPTOUT from the communication by following the "opt-out" link in the resource. For Inbox type of message, the user can also READ it and DELETE

  • The communication is always connected to some resource (template), presented as resource_id, and in case the resource has variations, by the resource_variation_id

  • Note that smartico is tracking the fact of any communication only 30 days after it's created

Partitioned by: fact_date

Data availability: last 1080 days by fact_date

Primary key: engagement_id + fact_type_id + fact_date

Table structure:

Column
Type
Note

fact_date

timestamp

The date/time when fact happened

user_id

int64

fact_type_id

int64

CREATE = 1 SENT = 2 IMPRESSION = 3 CLICK = 4 FAIL = 5 DELIVERED = 6 OPTOUT = 7 READ = 8 (for Inbox only) DELETE = 9 (for Inbox only)

fact_details

string

for CLICK fact - the link that was clicked for FAIL - the detailed reason for fail

activity_type_id

int64

Type of activity that triggered that communication (FK: dm_activity_type)

engagement_uid

uuid

Reference to the j_engagements, represents the point in the Campaign/Flow from where the communication was triggered

resource_id

int64

FK: dm_resource, main resource

resource_variation_id

int64

FK: dm_resource, specific variation of the resource

root_audience_id

int64

FK: dm_audience, the campaign that triggered communication

root_engagement_uuid

uuid/string

Reference to the j_engagements, represents the "root" point in the Campaign/Flow from where the communication was triggered

root_engagement_create_date

timestamp

The date when the campaign that triggered specific communication is started for the user

engagement_id

int64

Similar to engagement_uid, but in the int64 presentation

communication_id

int64

The unique ID of the communication will be the same for all facts through which the communication is transitioning. The ID id generated on the fact CREATE(1)

audience_category_id

int64

Category of the campaign. 1 - Marketing 2 - Operational

external_id

string

ID of the communication assigned by the external gateway at the moment when the external gateway accepted communication from Smartico

label_provider_id

int64

ID of the communication provider (dm_providers_mail and dm_providers_sms)

planned_send_date

timestamp

In some setups, the campaign that creates communication is scheduling delivery for a later time, in such case planned_send_date will reflect this date

fail_reason_id

int64

ID of the fail reason, FK: dm_com_fail_reason

user_ext_id

string

The ID of the user in the operator system

crm_brand_id

int64

ID of the brand in the Smartico system

Example of query that returns counts of communication by status and provider for the past 7 days.

SELECT
    COALESCE(sm.provider_name, ml.provider_name) AS provider_name,
    DATE(c.fact_date) AS communication_date,
    CASE 
        WHEN c.fact_type_id = 1 THEN 'CREATE'
        WHEN c.fact_type_id = 2 THEN 'SENT'
        WHEN c.fact_type_id = 3 THEN 'IMPRESSION'
        WHEN c.fact_type_id = 4 THEN 'CLICK'
        WHEN c.fact_type_id = 5 THEN 'FAIL'
        WHEN c.fact_type_id = 6 THEN 'DELIVERED'
        WHEN c.fact_type_id = 7 THEN 'OPTOUT'
        WHEN c.fact_type_id = 8 THEN 'READ'
        WHEN c.fact_type_id = 9 THEN 'DELETE'
        ELSE 'UNKNOWN'
    END AS status_name,
    COUNT(*) AS status_count
FROM
    `dwh_ext_2283.j_communication` c
LEFT JOIN
    `dwh_ext_2283.dm_providers_sms` sm ON c.label_provider_id = sm.id
LEFT JOIN
    `dwh_ext_2283.dm_providers_mail` ml ON c.label_provider_id = ml.id
JOIN
    `dwh_ext_2283.dm_resource` r ON c.resource_id = r.resource_id
WHERE
    c.fact_date >= TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL 7 DAY)
    AND r.resource_type_id IN (1, 3) -- Filter for Mail (1) and SMS (3)
GROUP BY
    communication_date, provider_name, status_name
ORDER BY
    communication_date DESC, status_count DESC;

Example of query returning number of created, delivered, failed mails, with clicks, views metrics for each day and each campaign

WITH 
      eng_st_dt as (
            -- take all campaigns 'start' facts
                SELECT root_engagement_id,
                       DATE(create_date) as engagement_create_date
                FROM dwh_ext_xxx.j_engagements 
                WHERE activity_type_id = 1
                AND DATE(create_date) = '2025-07-18'
      ),
      eng as (
            -- take all 'mail' activities starting from that date
            SELECT DISTINCT 
                      root_audience_id,
                      crm_brand_id,
                      engagement_id,
                      root_engagement_id,
            FROM dwh_ext_xxx.j_engagements
            WHERE DATE(create_date) >= '2025-07-18'
            AND activity_type_id = 50
        )
        -- check performance of communication realted to each campaign for each day
        SELECT
            S.engagement_create_date,
            R.root_audience_id as audience_id,
            A.audience_name,
            SUM(CASE WHEN C.fact_type_id = 1 THEN 1 ELSE 0 END) AS email_created,
            SUM(CASE WHEN C.fact_type_id = 2 THEN 1 ELSE 0 END) AS email_sent,
            COUNT(DISTINCT CASE WHEN C.fact_type_id = 3 THEN R.engagement_id ELSE NULL END) AS email_impression,
            COUNT(DISTINCT CASE WHEN C.fact_type_id = 4 THEN R.engagement_id ELSE NULL END) AS email_click,
            COUNT(DISTINCT CASE WHEN C.fact_type_id = 5 THEN R.engagement_id ELSE NULL END) AS email_fails
        FROM  eng R
        INNER JOIN  dwh_ext_xxx.j_communication AS C 
                ON C.engagement_id = R.engagement_id 
        INNER JOIN eng_st_dt S
                ON R.root_engagement_id= S.root_engagement_id 
        INNER JOIN dwh_ext_xxx.dm_audience A ON R.root_audience_id = A.audience_id
        WHERE  DATE(C.fact_date) >= '2025-07-18'
        GROUP BY
            R.root_audience_id,
            A.audience_name,
            S.engagement_create_date

dwh_ext_xxx.j_automation_rule_progress

The table represents the progress in automation rules.

Partitioned by: dt_executed

Data availability: last 1080 days by dt_executed

Primary key: no, but automation_rule_id + event_id can be used as PK

Table structure:

Column
Type
Note

automation_rule_id

int64

FK: dm_automation_rule

dt_executed

timestamp

time when the rule was executed

user_id

int64

Smartico User ID

activity_type_id

int64

FK: dm_activity_type Indication of activity type that was executed

user_ext_id

string

The ID of the user in the operator system

execution_count

int64

Number of times that rule was executed for one transaction. Value could be different from 1 in cases like "Give 1 point for 1 EUR bet", when user bet 3 EUR, the value will be 3

remaining_score

float54

For accumulated rules, e.g. give 1 eur for each 1 EUR bet, in case of 1.5 EUR bet, remaining value will be 0.5 EUR

event_id

int64

ID of event that triggered rule execution

scheduled_rule_log_id

int64

For scheduled automation rules, the ID of the execution batch

q_date

timestamp

For rules with qualification action, the date when rule was qualified

q_valid_till_date

timestamp

For rules with qualification action, the date till which the rule will stay qualified

q_event_uuid

string

For rules with qualification action, UUID of event that qualified the rule

user_ext_id

string

The ID of the user in the operator system

crm_brand_id

int64

ID of the brand in the Smartico system

dwh_ext_xxx.j_engagements

The table represents the steps of how the user enters the campaign, exits it, converts, and goes through all the "activities" of the Flow defined in the campaign.

The table represents the recursive structure of user transition over the campaign graph.

For most of the use cases, you will need to analyze only records that have activity_type_id as one of

  • 1 - represents the start of the campaign

  • 2 - stop the campaign

  • 3 - conversion of campaign

The table structure below describes only essential fields that could be used to analyze the campaign performance. If you need a deeper analysis, please contact [email protected] for an explanation.

Partitioned by: create_date

Data availability: last 1080 days by create_date

Primary key: engagement_id or engagement_uid

Table structure:

Column
Type
Note

engagement_id

int64

unique id

engagement_uid

uuid/string

same as unique id, but uuid presentation

root_audience_id

int64

FK: dm_audience

create_date

timestamp

time when user got this activity

user_id

int64

root_engagement_id

int64

reference to the same table pointing to the starting point of this campaign for the specific user

root_engagement_create_date

timestamp

The date when the campaign is started for a specific user

activity_type_id

int64

FK: dm_activity_type

user_ext_id

string

The ID of the user in the operator system

resource_id

int64

ID of the resource if the activity is related to the communication. Important that the field is populated retrospectively every night at 3 UTC

expected_stop_date

timestamp

Expected stop date/time of the campaign, set as create_date of the activity_type_id = 1 (start of the campaign) + campaign duration set in the BackOffice. Note that the campaign can be forcefully stopped inside the flow using "Stop" activity

ab_target

boolean

Indicating if the current element in the campaign flow was set as an AB test target for the communication element followed this target

from_control_group

boolean

Indicate if the entrance in the campaign was marked as "Control group" case. Users that are entering in the "Control group" will have engagements records with activity_type_id = 1,2,3. Because they are "Entering campaign" (1), they can "Stop in campaign" (2) and they can "Convert in campaign" (3), but there will be no other types of engagements as such users are not progressing through the flow

audience_id

int64

The ID of the "connector" in the campaign flow, the "arrow" that connects one activity to another one. In most of the cases not needed in any reports **

event_id

int64

Smartico ID of event that progressed the flow **

entry_event_details

JSON

The payload of event that triggered start of campaign **

activity_id

int64

ID of activity the flow **

event_type_id

int64

ID of type of event that progressed the flow **

root_audience_entry_mode_id

int64

Type of campaign entry mode:

ONCE_IN_A_LIFE = 0,
ONCE_IN_AN_OPEN_JOURNEY = 1,
EVERY_TIME_CONDITION_MET = 2,
STOP_AND_START = 3,

root_audience_exec_type_id

int64

Type of campaign

REALTIME = 1,
REALTIME_OPERATIONAL = 2,
SCHEDULED = 3,
SCHEDULED_OPERATIONAL = 4,

activity_details_json

JSON

Definition of activity that was executed **

scheduled_audience_log_id

int64

ID of batch for the scheduled campaign. If campaign is recurring, this ID will indicate different time period when campaign started

ab_resources_cnt

int64

In A/B testing of the resource, count of number of times that resource was sent **

crm_brand_id

int64

ID of brand in Smartico system to which user belongs

Fields marked with ** are given mainly for reference and rarelly can be used in any type of reports

Example of query that returns

  • data of label 2305

  • users entered campaign 793485 after 20/11/2023

  • and converted in this campaign

   WITH SRC AS (
        SELECT 
            engagement_id,
            root_audience_id,
            root_engagement_id,
            root_engagement_create_date,
            user_id,
            engagement_uid,
            activity_type_id,
            create_date,
            from_control_group,
            activity_id
        FROM dwh_ext_xxx.j_engagements
        WHERE label_id = 2305 AND activity_type_id in (1,2,3)
            AND root_audience_id IN (793485)
            AND create_date >= '2023-11-20T00:00:00Z'
            AND root_engagement_create_date >= '2023-11-20T00:00:00Z'
            -- for the performance, you can limit upper date only with 30 days from the 'to', this is MAX duration of campaign
            AND create_date <= TIMESTAMP_ADD('2023-11-21T23:59:59Z', INTERVAL 31 DAY)
            AND root_engagement_create_date <= '2023-11-21T23:59:59Z'
    ),
    PREFINAL as (
        SELECT 
            SRC.root_audience_id, SRC.root_engagement_id, user_id,
            MAX(CASE WHEN SRC.activity_type_id = 1 then SRC.engagement_uid else null end) as root_engagement_uid,
            MAX(CASE WHEN SRC.activity_type_id = 1 then SRC.create_date ELSE NULL END) as start_date,
            MAX(CASE WHEN SRC.activity_type_id = 3 then SRC.create_date ELSE NULL END) as convert_date,
            MAX(CASE WHEN SRC.activity_type_id = 2 then SRC.create_date ELSE NULL END) as stop_date,   
            MAX(CASE WHEN SRC.activity_type_id = 1 THEN SRC.from_control_group ELSE NULL END) as from_control_group
        FROM SRC
        WHERE true
        GROUP BY SRC.root_audience_id, SRC.root_engagement_id, SRC.user_id
    ),
    FINAL as (
        SELECT 
            COUNT(*) OVER() AS cnt, ROW_NUMBER() OVER(ORDER BY PREFINAL.start_date DESC) AS row,
            PREFINAL.*,
        FROM PREFINAL
        WHERE true AND convert_date IS NOT NULL
    )
    SELECT *
    FROM FINAL

dwh_ext_xxx.j_bonuses

The table represents the history of bonuses given to users, including all the attempts to issue bonuses through the API provided by the platform.

Each bonus fact can be represented in the table multiple times, where each time it reflects the change in the lifecycle of the bonus. The status of the bonus is refllected in the column bonus_status_id with possible values:

  • 1 - NEW

  • 3 - REDEEMED

  • 4 - REDEEM_FAILED

Partitioned by: fact_date

Data availability: last 1080 days by fact_date

Primary key: bonus_id

Table structure:

Column
Type
Note

fact_date

timestamp

the date of the fact

bonus_id

int64

unique ID of the transaction preserved for all facts of this transaction

user_id

int64

Smartico user ID

user_ext_id

string

The ID of the user in the operator system

crm_brand_id

int64

ID of the brand in the Smartico system

bonus_status_id

int64

status of bonus as explained above

bonus_cost_value

int64

Shows the indicative value of real money spent on bonuses issued from the Smartico system if previosly defined in the bonus templates.

label_bonus_template_id

int64

ID of template in the smartico system

source_product_id

int64

ID of the sub-system that issued the bonus, e.g. 0 - Campaign 9 - Automation rule 100 - Gamification

125 - Dynamic Bonuses engine

126 - Manual bonus 5000 - Store 8000 - Tournament 8001 - Mini-game for Retention user 8002 - Mini-game for Visitor

source_product_ref_id

int64

ID that can be used to connect with the source product. For example if the source_product_id is a Campaign, then the value here will correspond to the event_id in the j_engagments table

engagement_uid

uuid/string

UID that matches the same in the j_engagments table

entity_id

int64

ID of the entity related to the source_product_id that issued the bonus. e.g. If issued by the Automation Rule, this ID will represent ID of the rule.

root_audience_id

int64

Similar to the entity_id, but should be used for the Campaign reference

error_code

int64

Error code in case of failed to issue bonus

error_message

string

The detailed error message

bonus_cost_value

numeric

The value of bonus cost as specified by operator in the template in Smartico BackOffice

bonus_internal_meta

json

Meta information related to the bonus template, specific for integration. If your bonus API is expecting template id/name, wagering requirements, or any additional parameters, they can be found here. As minimum it contains template_name/id as it defined in your system { "template_name":"SMRT-CASH-10" }

activity_details

json

Meta information about activity, stores additional details about details of bonus and activity that gave it. Example { "bonus_amount": 10, "bonus_cost_value": "0", "given_by_product_id": 5000, "given_by_product_name": "SHOP", "given_by_product_reference_id": 5155164, "label_bonus_template_id": 1199, "redeem_automatically": false, "ui_amount": "$10 Cash" }

Example of query that returns final statuses of bonuses in the defined period

WITH MAIN AS (
    SELECT
        JB.fact_date as create_date,
        JB.bonus_id,
        JB.user_id,
        JB.label_id,
        JB.crm_brand_id,
        JB,source_product_id,
        JB,source_product_ref_id,
        JB,root_audience_id,
        JB,bonus_status_id,
        JB,label_bonus_template_id,
        JB,entity_id,
        RANK() OVER (PARTITION BY bonus_id ORDER BY fact_date DESC) AS rank_desc,
        RANK() OVER (PARTITION BY bonus_id ORDER BY fact_date ASC) AS rank_asc
    FROM dwh_ext_2283.j_bonuses JB
    WHERE JB.fact_date >= '2024-04-01T00:00:00Z' AND JB.fact_date < '2024-04-15T23:59:59.000Z'
),
FINAL AS (
    SELECT
        A.*,
        B.create_date AS bonus_create_date,
        B.entity_id AS entity_id
    FROM MAIN A
    LEFT JOIN MAIN B ON B.rank_asc = 1 AND A.bonus_id = B.bonus_id
    WHERE A.rank_desc = 1 AND (B.create_date >= '2024-04-01T00:00:00Z' AND B.create_date < '2024-04-15T23:59:59Z')
        AND true
)
SELECT *
FROM FINAL

Example of query to get the bonuses count and cost, related to (issued by) campaigns for yesterday.

SELECT
    da.audience_id AS campaign_id,            
    da.audience_name AS campaign_name,        
    COUNT(DISTINCT jb.bonus_id) AS bonus_count, 
    SUM(jb.bonus_cost_value) AS total_bonus_cost,
    ARRAY_AGG(DISTINCT dbt.public_name) AS bonus_names 
    -- Aggregate distinct public names of bonuses into an array
FROM
    `dwh_ext_XXXXX.j_bonuses` AS jb          
JOIN
    `dwh_ext_XXXXX.j_engagements` AS je    
ON
    jb.source_product_ref_id = je.engagement_id  
    -- Join bonuses to engagements on related engagement id
JOIN
    `dwh_ext_XXXXX.dm_audience` AS da
ON
    je.audience_id = da.audience_id  
JOIN
    `dwh_ext_XXXXX.dm_bonus_template` AS dbt 
ON
    jb.label_bonus_template_id = dbt.label_bonus_template_id 
    DATE(je.create_date) = DATE_SUB(CURRENT_DATE(), INTERVAL 1 DAY) 
    AND DATE(jb.fact_date) = DATE_SUB(CURRENT_DATE(), INTERVAL 1 DAY) 
GROUP BY
    1, 2           

Example of query to get transactions issued from Dynamic Bonuses engine

SELECT 
    fact_date as create_date,
    user_id,
    user_ext_id, 
    redeem_date, 
    // bonus amount calculated by formula in the user currency
    JSON_VALUE(bonus_meta,'$.bonusAmount') as bonus_amount
FROM dwh_ext_2283.j_bonuses
WHERE TIMESTAMP_TRUNC(fact_date, DAY) = TIMESTAMP("2024-10-15") 
    and source_product_id = 125 -- issued by dynamic bonuses
    and bonus_status_id = 3 -- show only redeemed transactions

dwh_ext_xxx.j_webhooks_facts

The table represents the history of executing webhooks.

Webhooks can be triggered from Campaigns, Automation rules and upon completing the mission.

Partitioned by: fact_date

Data availability: last 1080 days by fact_date

Primary key: engagement_uid

Table structure:

Column
Type
Note

fact_date

timestamp

the date of the fact

details

STRING/JSON

JSON structure holding details of HTTP request that was executed

http_code

int64

The code returned by the target web server during execution.

response

STRING/JSON

JSON structuring holding details of HTTP response from the target web server

user_id

int64

Smartico ID of the user in the context of which the webhook was executed

user_ext_id

STRING

ID of the user in the exteranl syste,

crm_brand_id

int64

Smartico ID of the brand in Smartico syste to which the user belongs

source_product_id

int64

ID of the sub-system that initiated the webhook, e.g. 0 - Campaign 9 - Automation rule 100 - Gamification (Missions)

source_product_ref_id

int64

ID that can be used to connect with the source product. For example if the source_product_id is a Campaign, then the value here will correspond to the event_id in the j_engagments table

engagement_uid

uuid/string

UID that matches the same in the j_engagments table

root_audience_id

int64

Similar to the entity_id, but should be used for the Campaign reference (dm_audience table)

audience_activity_id

int64

ID of audience activity that represents uniquely the block in the campaign flow. Relevant only for webhooks executed from campaign, for other contexts will keep 0 value

Last updated

Was this helpful?