Skip to content

ConductorOne/baton-okta

Repository files navigation

Baton Logo

baton-okta Go Reference ci verify

baton-okta is a connector for Okta built using the Baton SDK. It communicates with the Okta API to sync data about which groups and users have access to applications, groups, and roles within an Okta domain.

Check out Baton to learn more about the project in general.

Getting Started

brew

brew install conductorone/baton/baton conductorone/baton/baton-okta BATON_API_TOKEN=oktaAPIToken BATON_DOMAIN=domain-1234.okta.com baton-okta baton resources 

Or auth using a public/private keypair

BATON_OKTA_CLIENT_ID=appClientID \ BATON_OKTA_PRIVATE_KEY='auth.key' \ BATON_OKTA_PRIVATE_KEY_ID=appKID \ BATON_DOMAIN=domain-1234.okta.com baton-okta baton resources 

docker

docker run --rm -v $(pwd):/out -e BATON_API_TOKEN=oktaAPIToken -e BATON_DOMAIN=domain-1234.okta.com ghcr.io/conductorone/baton-okta:latest -f "/out/sync.c1z" docker run --rm -v $(pwd):/out ghcr.io/conductorone/baton:latest -f "/out/sync.c1z" resources 

source

go install github.com/conductorone/baton/cmd/baton@main go install github.com/conductorone/baton-okta/cmd/baton-okta@main BATON_API_TOKEN=oktaAPIToken BATON_DOMAIN=domain-1234.okta.com baton-okta baton resources 

Data Model

baton-okta will pull down information about the following Okta resources:

  • Applications
  • Groups
  • Roles
  • Users
  • Custom-Roles
  • Resource-Sets
  • Resourceset-Bindings

By default, baton-okta will sync information for inactive applications. You can exclude inactive applications setting the --sync-inactive-apps flag to false.

For syncing custom roles --sync-custom-roles must be provided. Its default value is false.

We have also introduced resourceset-bindings(resourcesetID and custom roles ID) for provisioning custom roles and members.

Resourceset-bindings, custom roles and members(Users or Groups) usage:

  • Let's use some IDs for this example
Resource Set `iamkuwy3gqcfNexfQ697` Custom Role `cr0kuwv5507zJCtSy697` Member `00ujp51vjgWd6ylZ6697` 
  • Granting custom roles for users.
BATON_API_TOKEN='oktaAPIToken' BATON_DOMAIN='domain-1234.okta.com' baton-okta \ --grant-entitlement 'resourceset-binding:iamkuwy3gqcfNexfQ697:cr0kuwv5507zJCtSy697:member' --grant-principal-type 'user' --grant-principal '00ujp51vjgWd6ylZ6697' 

In the previous example we granted the custom role cr0kuwv5507zJCtSy697 to user 00ujp5a9z0rMTsPRW697.

  • Revoking custom role grants(Unassigns a Member)
BATON_API_TOKEN='oktaAPIToken' BATON_DOMAIN='domain-1234.okta.com' baton-okta \ --revoke-grant 'resourceset-binding:iamkuwy3gqcfNexfQ697:cr0kuwv5507zJCtSy697:member:user:00ujp51vjgWd6ylZ6697' 
  • Revoking everything associated to custom role(Deletes a Binding of a Role)
BATON_API_TOKEN='oktaAPIToken' BATON_DOMAIN='domain-1234.okta.com' baton-okta \ resource-set:iamkuwy3gqcfNexfQ697:bindings:custom-role:cr0kuwv5507zJCtSy697 

Contributing, Support and Issues

We started Baton because we were tired of taking screenshots and manually building spreadsheets. We welcome contributions, and ideas, no matter how small -- our goal is to make identity and permissions sprawl less painful for everyone. If you have questions, problems, or ideas: Please open a Github Issue!

See CONTRIBUTING.md for more details.

baton-okta Command Line Usage

baton-okta Usage: baton-okta [flags] baton-okta [command] Available Commands: capabilities Get connector capabilities completion Generate the autocompletion script for the specified shell config Get the connector config schema health-check Check the health of a running connector help Help about any command Flags: --api-token string The API token for the service account ($BATON_API_TOKEN) --auth-method string ($BATON_AUTH_METHOD) --cache Enable response cache ($BATON_CACHE) (default true) --cache-tti int Response cache cleanup interval in seconds ($BATON_CACHE_TTI) (default 60) --cache-ttl int Response cache time to live in seconds ($BATON_CACHE_TTL) (default 300) --client-id string The client ID used to authenticate with ConductorOne ($BATON_CLIENT_ID) --client-secret string The client secret used to authenticate with ConductorOne ($BATON_CLIENT_SECRET) --domain string required: The URL for the Okta organization ($BATON_DOMAIN) --external-resource-c1z string The path to the c1z file to sync external baton resources with ($BATON_EXTERNAL_RESOURCE_C1Z) --external-resource-entitlement-id-filter string The entitlement that external users, groups must have access to sync external baton resources ($BATON_EXTERNAL_RESOURCE_ENTITLEMENT_ID_FILTER) -f, --file string The path to the c1z file to sync with ($BATON_FILE) (default "sync.c1z") --filter-email-domains strings Only sync users with primary email addresses that match at least one of the provided domains. When unset or empty, all users will be synced. ($BATON_FILTER_EMAIL_DOMAINS) --health-check Enable the HTTP health check endpoint ($BATON_HEALTH_CHECK) --health-check-port int Port for the HTTP health check endpoint ($BATON_HEALTH_CHECK_PORT) (default 8081) -h, --help help for baton-okta --http-timeout-seconds int HTTP client timeout in seconds (max 1800) ($BATON_HTTP_TIMEOUT_SECONDS) (default 300) --log-format string The output format for logs: json, console ($BATON_LOG_FORMAT) (default "json") --log-level string The log level: debug, info, warn, error ($BATON_LOG_LEVEL) (default "info") --log-level-debug-expires-at string The timestamp indicating when debug-level logging should expire ($BATON_LOG_LEVEL_DEBUG_EXPIRES_AT) --okta-client-id string The Okta Client ID ($BATON_OKTA_CLIENT_ID) --okta-private-key string The Okta Private Key. This can be the whole private key or the path to the private key ($BATON_OKTA_PRIVATE_KEY) --okta-private-key-id string The Okta Private Key ID ($BATON_OKTA_PRIVATE_KEY_ID) --otel-collector-endpoint string The endpoint of the OpenTelemetry collector to send observability data to (used for both tracing and logging if specific endpoints are not provided) ($BATON_OTEL_COLLECTOR_ENDPOINT) -p, --provisioning This must be set in order for provisioning actions to be enabled ($BATON_PROVISIONING) --skip-entitlements-and-grants This must be set to skip syncing of entitlements and grants ($BATON_SKIP_ENTITLEMENTS_AND_GRANTS) --skip-full-sync This must be set to skip a full sync ($BATON_SKIP_FULL_SYNC) --skip-secondary-emails Skip syncing secondary emails ($BATON_SKIP_SECONDARY_EMAILS) --sync-custom-roles Enable syncing custom roles ($BATON_SYNC_CUSTOM_ROLES) --sync-inactive-apps Whether to sync inactive apps or not ($BATON_SYNC_INACTIVE_APPS) (default true) --sync-resources strings The resource IDs to sync ($BATON_SYNC_RESOURCES) --sync-resource-types strings The resource type IDs to sync ($BATON_SYNC_RESOURCE_TYPES) --sync-secrets Whether to sync secrets or not ($BATON_SYNC_SECRETS) --ticketing This must be set to enable ticketing support ($BATON_TICKETING) -v, --version version for baton-okta Use "baton-okta [command] --help" for more information about a command. 

About

No description, website, or topics provided.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

 
 
 

Contributors