VerticaUserPassword#
Maps Airflow Vertica connections using username + password authentication to dbt profiles.
Note
Use Airflow connection
schemafor verticadatabaseto keep it consistent with other connection types and profiles. The Vertica Airflow provider hook assumes this.This seems to be a common approach also for Postgres, Redshift and Exasol since there is no
databasefield in Airflow connection andschemais not required for the database connection.
This profile mapping translates Airflow connections with the type vertica
into dbt profiles. To use this profile, import it from cosmos.profiles:
from cosmos.profiles import VerticaUserPasswordProfileMapping
profile = VerticaUserPasswordProfileMapping(
    conn_id = 'my_vertica_connection',
    profile_args = { ... },
)
While the profile mapping pulls fields from Airflow connections, you may need to supplement it
with additional profile_args. The below table shows which fields are required, along with those
not required but pulled from the Airflow connection if present. You can also add additional fields
to the profile_args dict.
| dbt Field Name | Required | Airflow Field Name | 
|---|---|---|
| 
 | True | 
 | 
| 
 | True | 
 | 
| 
 | True | 
 | 
| 
 | False | 
 | 
| 
 | True | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | False | 
 | 
| 
 | True | 
Some notes about the table above:
- This table doesn’t necessarily show the full list of fields you can pass to the dbt profile. To see the full list of fields, see the link to the dbt docs at the top of this page. 
- If the Airflow field name starts with an - extra., this means that the field is nested under the- extrafield in the Airflow connection. For example, if the Airflow field name is- extra.token, this means that the field is nested under- extrain the Airflow connection, and the field name is- token.
- If there are multiple Airflow field names, the profile mapping looks at those fields in order. For example, if the Airflow field name is - ['password', 'extra.token'], the profile mapping will first look for a field named- password. If that field is not present, it will look for- extra.token.