Capabilities
| Resource | Sync | Provision |
|---|---|---|
| Accounts | ||
| Repositories | ||
| Teams | ||
| Orgs | ||
| Secrets - API keys |
Gather GitHub credentials
Configuring the connector requires you to pass in credentials generated in GitHub. Gather these credentials before you move on. To set up the GitHub connector, you can choose to create a personal access token (classic), a fine-grained access token, or a GitHub app. You must set up the connector with a GitHub app to have the option of syncing secrets.Option 1: Use a personal access token (classic)
Follow these instructions to integrate your GitHub instance by using a GitHub personal access token (classic).Select the following Scopes:
- repo - select all
- admin:org - select all if using ConductorOne for GitHub provisioning (see the note below), or read::org otherwise
- user - select all
Option 2: Use a fine-grained access token
Follow these instructions to integrate your GitHub instance by using a GitHub fine-grained personal access token.Name your token (for example, ConductorOne Integration) and set a token expiration date. Optionally, add a description.
In the Resource owner dropdown, select a resource owner. The token is able to access resources owned by the selected resource owner. Organizations will not appear unless they have opted in to fine-grained personal access tokens.
In the Permissions section of the page, give the token the following permissions:
-
Organization permissions:
- Members: Read and write access
- Custom organization roles: Read and write access
-
Repository permissions:
- Administration: Read and write access
- Metadata: Read-only access
Option 3: Use a GitHub app
Follow these instructions to integrate your GitHub instance by using a GitHub app. This process creates a GitHub app that is only available to your GitHub organization, then generates an installation token for that app, which can be used to integrate the GitHub organization with ConductorOne. This creates the equivalent of a personal access token, but does not tie the token to a specific identity. If you want to integrate multiple GitHub organizations with ConductorOne, you must create an app and set up a connector for each one.Give the app a globally unique name, such as “c1-integration-
<org name>”. There is a 34 character limit.In the Homepage URL field, enter a placeholder URL such as
http://example.com. Because this app is not public, it does not have or need a website to direct other users to, so we can use a placeholder URL.In the Callback URL field, enter a placeholder URL such as
http://example.com. This app will not use a callback, so we can use a placeholder URL.Check the Expire user authorization tokens and Enable Device Flow checkboxes to enable these settings.
In the Permissions section of the page, give the app the following permissions:
-
Repository permissions:
- Administration: Read and write access
- Metadata: Read-only access
-
Organization permissions:
- Custom organization roles: Read and write access
- Members: Read and write access
In the Where can this app be installed? section of the page, choose Only on this account. This limits the app’s scope to the GitHub Enterprise organization you’ve set it up on.
Finally, install the new app on your GitHub organization. Navigate to Developer Settings > GitHub Apps.
Configure the GitHub connector
- Cloud-hosted
- Self-hosted
Follow these instructions to use a built-in, no-code connector hosted by ConductorOne.That’s it! Your GitHub connector is now pulling access data into ConductorOne.
Choose how to set up the new GitHub connector:
- Add the connector to a currently unmanaged app (select from the list of apps that were discovered in your identity, SSO, or federation provider that aren’t yet managed with ConductorOne)
- Add the connector to a managed app (select from the list of existing managed apps)
- Create a new managed app
Set the owner for this connector. You can manage the connector yourself, or choose someone else from the list of ConductorOne users. Setting multiple owners is allowed.If you choose someone else, ConductorOne will notify the new connector owner by email that their help is needed to complete the setup process.
If you’re using a personal access token to set up the connector:
- Click Personal access token.
- Paste the token you generated into the Personal access token field.
- Optional. If you want to sync only specific GitHub organizations, enter the organizations’ names in the Orgs field. If you do not specify specific organizations, ConductorOne will sync all organizations.
- Optional. If you do not want to include archived repos in syncs, click to enable Omit archived repositories.
If you’re using a GitHub app to set up the connector:
- Click GitHub app.
- Enter your app ID into the GitHub app ID field.
- Click Choose file and upload your private key file.
- In the Organization field, enter the name of the GitHub organization associated with the GitHub app. You must enter a single organization name in this field or the connector configuration will fail.
- Optional. Click to enable Sync secrets. Synced secrets are displayed on the Inventory page.
- Optional. If you do not want to include archived repos in syncs, click to enable Omit archived repositories.