Skip to content

Commit

Permalink
chore: call aws secretsmanager
Browse files Browse the repository at this point in the history
JIRA:CLOUDSEC-12
  • Loading branch information
katebygrace committed Nov 27, 2023
1 parent 3fe2ec5 commit a2d7d19
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 1 deletion.
6 changes: 5 additions & 1 deletion dataeng/resources/model-transfers.sh
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,11 @@ fi

ARGS="{mart: ${MART_NAME} }"

dbt deps --profiles-dir $WORKSPACE/analytics-secure/warehouse-transforms/ --profile $DBT_PROFILE --target $DBT_TARGET
DBT_TARGET="prod"

source secrets-manager.sh analytics-secure/warehouse-transforms/profiles DBT_PASSWORD

dbt deps --profiles-dir . --profile $DBT_PROFILE --target $DBT_TARGET

# Call DBT to perform all transfers for this mart.
dbt run-operation perform_s3_transfers --args "${ARGS}" --profile $DBT_PROFILE --target $DBT_TARGET --profiles-dir $WORKSPACE/analytics-secure/warehouse-transforms/
99 changes: 99 additions & 0 deletions dataeng/resources/profiles.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
# This prevents dbt from rebuilding the DAG every run, saving time on jobs where it is run repeatedly
config:
partial_parse: True

warehouse_transforms: # This is the name to use for "profile"
target: prod # The default target.
outputs: # Each of the keys in this dict is a "target"
dev:
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER
role: DBT_TRANSFORMER_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: DEV
warehouse: TRANSFORMING
# This becomes the prefix for schemas written to by this target, e.g. "123456789_finance" if DEV_SCHEMA_PREFIX=123456789.
# dbt calls this the "target schema" in their docs
schema: "{{ env_var('DEV_SCHEMA_PREFIX') }}"
threads: 10
prod:
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER
role: DBT_TRANSFORMER_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: PROD
warehouse: TRANSFORMING
# This is not a real schema name or schema prefix---the generate_schema_name_for_env macro will take care of
# removing this prefix string. Resulting schema names end up being just "finance" or whatever is defined in the
# schema.yml level as a "custom schema".
# dbt calls this the "target schema" in their docs
schema: NO_PREFIX
threads: 10
edge:
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER
role: DBT_TRANSFORMER_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: EDGE
warehouse: TRANSFORMING
# This is not a real schema name or schema prefix---the generate_schema_name_for_env macro will take care of
# removing this prefix string. Resulting schema names end up being just "finance" or whatever is defined in the
# schema.yml level as a "custom schema".
# dbt calls this the "target schema" in their docs
schema: NO_PREFIX
threads: 10
prod_amplitude:
# This target is specifically for running amplitude models, which are relatively time sensitive.
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER
role: DBT_TRANSFORMER_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: PROD
warehouse: TRANSFORMING
schema: NO_PREFIX
threads: 10
prod_load_incremental:
# This environment is for dbt initial loading (or reloading) of large incremental tables in DBT that need a larger warehouse
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER
role: DBT_TRANSFORMER_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: PROD
warehouse: TRANSFORMING_XL
# This is not a real schema name or schema prefix---the generate_schema_name_for_env macro will take care of
# removing this prefix string. Resulting schema names end up being just "finance" or whatever is defined in the
# schema.yml level as a "custom schema".
# dbt calls this the "target schema" in their docs
schema: NO_PREFIX
threads: 10
ci_tests:
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER_CI
role: DBT_TRANSFORMER_CI_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: CI_TESTS
warehouse: TRANSFORMING_CI
# The following schema name CI_SCHEMA_NAME is actually a keyword that is used to search and replace in a
# sed command. That is replaced by the actual schema name generated in jenkins job such as PR_1724.
#schema: CI_SCHEMA_NAME
schema: "{{ env_var('CI_SCHEMA_NAME') }}"
threads: 10
ci_tests_large:
type: snowflake
account: edx.us-east-1
user: DBT_TRANSFORMER_CI
role: DBT_TRANSFORMER_CI_ROLE
password: "{{ env_var('DBT_PASSWORD') }}"
database: CI_TESTS
warehouse: TRANSFORMING_CI_L
# The following schema name CI_SCHEMA_NAME is actually a keyword that is used to search and replace in a
# sed command. That is replaced by the actual schema name generated in jenkins job such as PR_1724.
#schema: CI_SCHEMA_NAME
schema: "{{ env_var('CI_SCHEMA_NAME') }}"
threads: 10

0 comments on commit a2d7d19

Please sign in to comment.