-
Notifications
You must be signed in to change notification settings - Fork 447
Description
I'm working on a script that would push one workbook to multiple Tableau sites. Each site has a different database to connect to, so the embedded connection needs to be updated appropriately.
I'm trying to accomplish this by updating the embedded datasource connection information in the packaged workbook. Feel free to let me know if there's a better way to do this as I'm new to Tableau in general.
Currently, I have this:
conn_creds = TSC.ConnectionCredentials(name=rds_user,
password=rds_pass)
# Create a connection and add the above credentials to it
connection = TSC.ConnectionItem()
connection.server_address = rds_host
connection.server_port = rds_port
connection.connection_credentials = conn_creds
# Publish the workbook to tableau
publish_item = server.workbooks.publish(new_workbook,
workbook_file,
publish_mode,
connections=[connection])This seems to work if the workbook was exported with the server_address set to the same thing as my rds_host above. So if rds_host and the server address in the workbook are both dev.example.com, it will update the credentials and publish correctly.
However, if rds_host is production.example.com and the workbook has dev.example.com, Tableau returns a failed to establish a connection to your datasource error message even though the credentials are correct.
Before I tried the above solution, I was using the (now deprecated?) connection_credentials attribute like this:
conn_creds = TSC.ConnectionCredentials(name=rds_user,
password=rds_pass)
# Publish the workbook to tableau
publish_item = server.workbooks.publish(new_workbook,
workbook_file,
publish_mode,
connection_credentials=conn_creds)This had the same effect of updating the username/password correctly, but would not update the server_address.
https://tableau.github.io/server-client-python/docs/api-ref#workbooks under workbooks.publish actually does not mention the connections= attribute at all, only connection_credentials. There was a warning message logged saying it was deprecated that lead me to use connections.
https://tableau.github.io/server-client-python/docs/api-ref#connections under ConnectionCredentials class mentions server_address and server_port attributes, but they don't seem to exist in https://github.com/tableau/server-client-python/blob/v0.7/tableauserverclient/models/connection_credentials.py and aren't used in https://github.com/tableau/server-client-python/blob/v0.7/tableauserverclient/server/request_factory.py#L38
Please let me know if I need to clarify anything or if more information is needed. I haven't looked at the code too much for this library yet, but when I get some time I planned on testing the same process with the rest api directly to verify that it isn't an issue with the server api itself.