Skip to content

Latest commit

 

History

History

looker

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

Looker Connector

This connector extracts technical metadata from a LookML project and using Looker API.

Setup

We recommend creating a dedicated Looker user and role with limited permission for the connector to use.

  1. Log into your Looker instance.
  2. Go to Admin > Roles, click New Permission Set.
  3. Name the permission set Metaphor and select the following permissions to create the role:
    • access_data
      • see_lookml_dashboards
      • see_looks
        • see_user_dashboards
        • explore
      • see_sql
      • see_queries
      • see_logs
      • see_users
      • see_pdts
      • see_system_activity
  4. Click the New Role button to create a new role using the following:
    • Name: Metaphor
    • Permission Set: select Metaphor
    • Model Set: select All
    • Leave Groups and Users unselected
  5. Go to Admin > Users, click Add Users to create a new user using the following:
    • Email: You can use any email address as the user is only used for API access.
    • Send Setup Email: Unselect
    • Roles: Select Metaphor
    • Groups: Unselect

API Authentication

Now the user has been created, we need to generate the client ID & secret for Looker API access:

  1. Go to Admin > Users, click the new user's Edit button.
  2. Click the Edit Keys button under API3 Keys.
  3. Click New API3 Key, then note down the Client ID and Client Secret for the config file.

GitHub Action

The recommended way to run the connector in production is to integrate it as part of the CI/CD pipeline. Please refer to Metaphor Looker GitHub Action for more details.

The remaining sections are for those who intend to run the connector manually as a CLI or to integrate it into a different CI/CD environment.

Config File

Create a YAML config file based on the following template.

Required Configurations

base_url: <looker_base_url>
client_id: <client_id>
client_secret: <client_secret>
connections:
  <name>:
    database: <database_name>
    default_schema: <schema_name>
    account: <snowflake_account>
    platform: SNOWFLAKE

Note that connections is a mapping of database connection names to connection settings. You can find these settings under Admin > Connections. For now, the only platform supported is SNOWFLAKE with account set to the matching Snowflake Account Identifier.

The connector also needs to parse the LookML project to extract additional metadata. There are two ways to provide the project source code. If the source code is in local environment, we can set the path to the project root as following:

lookml_dir: <path_to_lookml_project>

Alternatively, if the source code is hosted on Git, we can set the git repository config as following:

lookml_git_repo:
  git_url: <git_repo_url>
  username: <username>
  access_token: <git_repo_personal_access_token>

For more information about git repo configuration, please refer to Git Repo Connection Config.

Optional Configurations

Project Source URL

To add a "View LookML" link to Looker explore & views on Metaphor you need to specify a base URL for the Looker project. This can be either a URL to the GitHub repository (https://github.com/<account>/<repo>) or Looker IDE (https://<account>.cloud.looker.com/projects/<project>/files/).

project_source_url: <looker_project_source_url>

Alternative Server URL

If the looker users use a different URL to view content on Looker than the server URL for fetching metadata, please provide the alternative base URL so the crawler can generate direct links to the assets:

alternative_base_url: <looker_base_url> // e.g. https://looker.my_company.com

Ignored Model Files

You can also specify a list of model files to ignore by using the following config. The pattern is matched against the relative path of the model file from the project base directory.

ignored_model_files:
  - "model1.model.lkml"
  - "tmp/*"

SSL Verification

You can also disable SSL verify and change the request timeout if needed, e.g.

verify_ssl: false 
timeout: 30  # default 120 seconds

Looker Explore/View folder name

Looker explores and Looker views will be put in a folder named "Looker Models" by default. You can customize the name by using this config:

explore_view_folder_name: "Looker Views & Explores"  # default to "LookML Models"

Output Destination

See Output Config for more information on the optional output config.

Testing

Follow the Installation instructions to install metaphor-connectors in your environment (or virtualenv). Make sure to include either all or looker extra.

Run the following command to test the connector locally:

metaphor looker <config_file>

Manually verify the output after the command finishes.