Atlassian Bitbucket Connector
Index repositories, projects, pull requests, commits, and comments in Bitbucket.
Note: Configuration of sources is regularly evolving and curretly requires access to the kubernetes custer. This document covers responsibilities shared by both the Deployment Engineer and Admin.
Atolio can be configured to index content across a variety of sources. This document describes the steps required in both the source systems and within Atolio:
All source configuration in Atolio is currently performed by your Deployment Engineer. It is accomplished using atolioctl
which is a terminal based UI (TUI) that allows your Deployment Engineer to configure all available sources. In the future, this interface will be a browser-based IT Administrator function.
Atolio provides an installer script within the lumen-infra
repository that will automatically grab the latest version of atolioctl
and install it locally.
Note: The installer script requires that you have
curl
orwget
installed:
lumen-infra
repository and into the scripts directorycd lumen-infra/deploy/terraform/scripts
./get-atolioctl.sh
atolioctl --help
You can re-run this script to download the latest version of atolioctl
or run the script with the --version
flag to install a specific version of atolioctl
, ex:
./get-atolioctl.sh --version 4.10.2
Prior to configuring a source, the connector (ie the deployment in which the source will run on) must be deployed. Atolio uses the concept of instances to support one or more instances of a source (eg multiple tenants), and the creation of these deployments is managed by modifying values-lumen.yaml
. Specify connectors like so:
connectors:
microsoft:
default:
enabled: true
okta:
default:
enabled: true
jiracloud:
default:
enabled: true
Connectors are deployed under a default
instance. This is an identifier which can be changed as desired, and multiple connectors can be deployed under different instances. Once the instance is set, it should be treated immutable. Modifying this value will result in loss of data and a need to re-index under the new instance. This is due to the instance being part of every resource identifier ingested by Atolio.
jiracloud:
internal:
enabled: true
external:
enabled: true
The above YAML examples are the minimal definitions required to deploy a connector to your Atolio cluster. There are additional properties that can be set in your values-lumen.yaml
file as directed by your Atolio support team to apply different options. For example:
connectors:
google:
default:
enabled: true
lumenImageTag: 4.13.0-alpha1
log:
level: "debug"
resources:
requests:
cpu: 500m
memory: 2Gi
limits:
cpu: 1000m
memory: 4Gi
To provision the updates into the cluster, you’d upgrade the lumen
Helm chart by running create-infra.sh
(recommended) or:
helm upgrade lumen-chart ../../k8s/charts/lumen --values values-lumen.yaml --values values-lumen-templated.yaml -n atolio-svc
All source configuration is accomplished through atolioctl
which can be obtained through the Releases page. This is a terminal based UI (TUI) which allows an administrator to configure all available sources. In the future, this interface will be browser based.
This section details how to configure each source, including how to obtain the necessary JWT.
First an API token needs to be created for use with atolioctl
. This token can be generated as follows using the config.hcl
file that was used to run the create-infra.sh
script:
export JWT_TOKEN=$(atolioctl connector create-jwt --raw --config-dir . "atolio:*:*:*")
To run configuration, provide the configure
command to atolioctl
. Make sure to use the correct API host name for your deployment. Once loaded, you should see a collection of configuration options and sources in your terminal:
atolioctl configure --jwt-token-sdk ${JWT_TOKEN} --feeder-address feed.search.example.com:443
To run configuration, port-forward 8889
from service/feeder
and provide the configure
command to atolioctl. Ensure the correct AWS profile is in context. Once loaded, you should see a collection of configuration options and sources in your terminal:
kubectl port-forward -n atolio-svc service/feeder 8889
atolioctl configure --jwt-token-sdk ${JWT_TOKEN} --feeder-address :8889 --disable-feeder-tls
Note that for the time being all atolioctl
commands below (unless noted otherwise) will require the port forwarding command.
To obtain source-specific information, head to source configuration and find the source you’re interested in configuring. Some tips when running atolioctl:
?
to toggle the help menu / key map. You will typically use up/down arrows and <TAB>
to navigate the menus.Review & Save
is selected and validation has completed. A report will be shown detailing which sources were successfully configured and which not.Configuration of sources can be done without a functional stack and atolioctl
can output the configuration into a YAML file, which can be further hand-modified and imported when the stack is deployed.
Prior to an initial deployment, pre-configuring sources can expedite the initial deployment procedures and time on call. To configure sources before the stack is available, you can pass the --config-file
option:
atolioctl configure --config-file atolio.yaml
The file does not need to exist prior to running this command. You’ll be presented with the TUI and will be able to select and configure sources from the registry. Once configured, you can Review & Save
per typical procedure and atolioctl will output an atolio.yaml
file with the (valid) configuration persisted within the filesystem.
As a reminder, the stack is not yet running at this point. Configuration of most sources does not require an operational stack as the validation is simply making a call to the source API and there is no expectation of the source’s connector running yet. There are some exceptions (in particular Jira, Confluence, and BitBucket)
Once desired sources have been configured and the stack deployed, you can import the pre-configured file. Note at this point it’s expected Feeder is operational and port-forwarding to the service address can occur:
atolioctl configure import atolio.yaml --jwt-token-sdk ${JWT_TOKEN} --feeder-address :8889 --disable-feeder-tls
Writing key: /lumen/connectors/github/default/github
Writing key: /lumen/connectors/linear/default/linear
Writing key: /lumen/connectors/notion/default/notion
Writing key: /lumen/connectors/slack/default/slack
Writing key: /lumen/connectors/web/default/web
Writing key: /lumen/connectors/bitbucket/default/bitbucket
Similarly, source configuration of the stack can be exported to a local file. This can be useful if wishing to view the entire configuration in a human-readable YAML file, or perhaps store a backup of the configuration in a vault like 1Password. This file will be in the same format as the one imported in the prior step, allowing a loop of export, modify, import:
atolioctl configure export --jwt-token-sdk ${JWT_TOKEN} --feeder-address :8889 atolio.yaml --disable-feeder-tls
Both export and import commands can also combined into a single edit
command that exports the current source configuration into a text editor (specified by the EDITOR
environment variable) allowing manual edits. Upon saving/closing the editor, the configuration will be imported. This command is invoked a follows:
atolioctl configure edit --jwt-token-sdk ${JWT_TOKEN} --feeder-address :8889 --disable-feeder-tls
Atolio supports the ability to avoid certain content from being indexed at all. The example below shows how to specifically exclude a Jira project (with the project key “SP”).
When configuring the Jira source, enter the following in the Resources
field:
project:
excluded:
- "SP" # The Secret Project
The excluded
keyword contains a list of Jira project keys to be excluded from indexing. Similarly you can also use the included
keyword to achieve the opposite (in that case only those resources that are specifically listed will be indexed, nothing else). Note that the list entries (e.g. SP
in the example above) are case sensitive.
In the absence of both included
(opt-in) or excluded
(opt-out), everything that the credentials (e.g. API key) have access to will be indexed. Note that this is a layer on top of the permissions model provided to the source. Anything added to included
will only be indexed if the underlying credentials grant the indexing job access.
This feature is supported by a majority of Atolio connectors, see each connectors respective documentation for details and scope of inclusions / exclusions.
Index repositories, projects, pull requests, commits, and comments in Bitbucket.
Index spaces, pages, and comments in Confluence.
Index content from your Jira DC & Confluence DC environments.
Index projects, issues, and comments in Jira.
Index pull requests, commits, comments, and markdown in your GitHub repositories.
Index merge requests, commits, and comments in your GitLab projects.
Index documents, sheets, slides, files, and email across your Google Workspace (Google Drive and Gmail).
Index teams, projects, issues, and comments in Linear.
Integrate with Entra ID for user mappings. Index SharePoint sites and Teams channels.
Index databases, pages, and comments in Notion.
Provides app-user mappings stored in Okta.
Index top level resources such as Accounts, Contacts, Cases, Opportunities, Leads by installing a Connected App.
Search across your ITSM tasks (incidents, service requests, etc.) and knowledge base articles in ServiceNow.
Index public channels, private channels, and threads in Slack where the Atolio bot is present.
Index content on your SolarWinds Service Desk instance.
Index resources such as Users, Campaigns, Posts, and Comments from your Staffbase platform.
Index internal or external websites by crawling HTML pages and content.
Index tickets and help center articles on your Zendesk instance.