Getting Access
How to access the Partner Data Warehouse
Overview
Access to Monta's Partner Data Warehouse is based on Key Pair auth for now. Please note that not all BI or dashboard tools support this. If your solution does not support setting up access with private/public keys you won't be able to access the PDWH with it.
Requirements
To gain access to the Partner Data Warehouse, follow these steps:
-
Partnership and Agreement: Ensure you are part of our Partner Program and have a mutual data sharing agreement in place.
-
Key Generation:
- Generate a public and private key pair following this guide.
- Send us (Monta) the public key via email or Slack. This key is not secret and can be shared openly.
-
Access Information: Upon receiving your public key, we will provide you with the Snowflake account identifer and host URL needed to access the data warehouse. We will send this via Slack or email.
-
Connect to Snowflake:
- SnowSQL (Snowflake CLI tool)
- Snowflake Python Connector
- DBeaver or other compatible BI tools
Key Generation
- Key Pair Authentication offers enhanced security. Generate a 2048-bit RSA key pair as minimum, following the steps outlined in the Snowflake documentation.
- Client Support: Most Snowflake clients support key pair authentication and rotation, including SnowSQL, Python Connector, JDBC Driver, and others.
Steps for Key Configuration in Mac OS or Linux system (openssl library required)
-
Generate the Private Key: Use OpenSSL to generate a private key. We only support unencrypted keys.
openssl genrsa 2048 | openssl pkcs8 -topk8 -inform PEM -out rsa_key.p8 -nocrypt
-
Generate the Public Key: With the private key generated, produce the public key using OpenSSL.
- Command:
openssl rsa -in rsa_key.p8 -pubout -out rsa_key.pub
- Command:
Connecting to Snowflake
SnowSQL (Snowflake CLI tool)
Installing SnowSQL
You can find installation instructions for SnowSQL for your OS here
Connecting with SnowSQL
After installing SnowSQL you can connect to Snowflake and start querying your tables with the command below. Replacing {examplepartner}
with your partner name, and the ~/rsa_key.p8
with the location of your private key file.
snowsql -a st17140.eu-west-1 -h st17140.eu-west-1.snowflakecomputing.com -u {examplepartner} --private-key-path ~/rsa_key.p8 -w PARTNER -d PARTNER -s PRODUCTION_{examplepartner}
Snowflake Python Connector
You can use Python for programmatic access to your tables via the Snowflake Python connector.
Refer to the installation instructions in the Snowflake docs.
When connecting to Snowflake via the Python Connector, you should refer to the key-pair authentication part of the docs. Replacing the following values for user, warehouse, account etc. in the code example
user
: {examplepartner}
account
: The account identifier is provided by us, after we receive your public key.
warehouse
: "PARTNER"
database
: "PARTNER"
schema
: "PRODUCTION_{examplepartner}
Schema names may differ basing on how you connect
If your partner name contains hyphens, replace those with underscores. But only for the schema. E.g.
partner-one
becomespartner_one
DBeaver or other compatible BI tools
DBeaver has a free community edition . Download and follow instructions to install.
- Database→New Database Connection
data:image/s3,"s3://crabby-images/a59c8/a59c865f4fa9def45a36cdde10008f25f1fd143a" alt=""
- Find Snowflake and choose Next
data:image/s3,"s3://crabby-images/9ccba/9ccbacf8e0db7d838d37ed4d058518a3dcc66347" alt=""
- Fill in the info as in the screenshot below.
- Host:
st17140.eu-west-1.snowflakecomputing.com:443
- Database and Warehouse
PARTNER
- Schema
PRODUCTION_<PARTNER_NAME>
- Username
<PARTNER_NAME>
- Host:
Replace <PARTNER_NAME> with your relevant partner name.
data:image/s3,"s3://crabby-images/45b4d/45b4d96da1b32322b16e2d02abb7b1466d5be0e6" alt=""
- Driver properties → Right click and add new property. Call this private_key_file and press OK.
data:image/s3,"s3://crabby-images/7625e/7625ed030dc4ce4c511276434994f780377aecce" alt=""
data:image/s3,"s3://crabby-images/3ea2d/3ea2d11740139268dd7bbb4bfecc18b04cb5341b" alt=""
- Click right next to the field that now says
private_key_file
and put in the path to your private key as the value.
data:image/s3,"s3://crabby-images/a9624/a9624f80af7e4c8da938a715430c2e04fa573ebe" alt=""
- Click finish and you should see a Database called PARTNER under the Database Navigator
Updated 18 days ago