This repository houses the Java-based utilities for interacting with Atlan:
sdk
the Atlan Java SDK (client library), that ultimately calls through to Atlan's REST APIspackage-toolkit
for configuring, running and testing custom packagesintegration-tests
for automated regression-testinggenerate
to generate components of the SDK that are model-drivensamples
illustrating how the other components can be used for real automations and integrationsmocks
bundle wire mocks that are reused in unit tests across different projects
These additional directories serve other purposes:
containers
defines the container image that bundles the SDK and custom package toolkits, and container images for each custom package samplegradle
contains Gradle build bootstrapping and dependency version catalogbuildSrc
contains code for the Gradle multi-project build process (in particular, convention plugins)
For guides on actually using the various utilities housed in this repository, see: https://developer.atlan.com/getting-started/java-sdk/
To get started developing the SDK:
-
Clone the repository:
git clone ..
-
Ensure you have the Java 17 SDK installed. For example, on macOS:
brew install openjdk@..
To build the SDK, from within the root of the cloned repository:
./gradlew assemble shadowJar
Note that we use the Gradle build tool. This accelerates subsequent rebuilds through things like caching, and thus only needing to rebuild paths within the project that have changed from one build to another.
Before committing code, ensure it adheres to the repository's formatting guidelines. You can apply the required formatting using:
./gradlew spotlessApply
For running integration tests, you'll need to configure your environment:
- Copy the example environment file:
cp .env.example .env
- Update the
.env
file with your Atlan API key and base URL. - Export the environment variables:
- For macOS/Linux:
export $(cat .env | xargs)
- For Windows (PowerShell):
Get-Content .env | ForEach-Object { if ($_ -match '^(.*?)=(.*)$') { $env:($matches[1]) = $matches[2] } }
- For macOS/Linux:
You can run the SDK's unit tests without needing access to an Atlan environment:
./gradlew test
Once the environment is set up, you can run integration tests:
- Base SDK integration tests:
./gradlew test -PintegrationTests
- Package-specific integration tests:
./gradlew test -PpackageTests
Portions of the SDK are based on original work from https://github.com/stripe/stripe-java. Those classes that derive from this original work have an extra heading comment as follows:
/* Based on original code from https://github.com/stripe/stripe-java (under MIT license) */
The original MIT license under which these were used is included here:
The MIT License
Copyright (c) 2011- Stripe, Inc. (https://stripe.com)
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
License: CC BY 4.0, Copyright 2022 Atlan Pte. Ltd.