The Immutable Core SDK Kotlin/JVM provides convenient access to the Immutable API's for applications written on the Immutable X platform.
See the developer guides for information on building on Immutable X.
See the API reference documentation for more information on our API's.
- Create an Access Token (see here) with
read:packages
enabled. - Add the GitHub package as a repository either in your
build.gradle
file orsettings.gradle
if you have one:
repositories {
maven {
name = "imx-core-sdk-kotlin-jvm"
url = uri("https://maven.pkg.github.com/immutable/imx-core-sdk-kotlin-jvm")
credentials {
username = "<github username>"
password = "<access token>"
}
}
}
Note: will look to have this accessible directly via the mavenCentral()
repository in the future.
3. Add dependency to your app build.gradle
file:
dependencies {
implementation 'com.immutable.sdk:imx-core-sdk-kotlin-jvm:$version'
}
- Set the correct environment (Ropsten or Production/Mainnet)
ImmutableXCore.setBase(ImmutableXBase.Ropsten)
The Core SDK includes classes that interact with the Immutable X APIs.
e.g. Get a list of collections ordered by name in ascending order
val response = CollectionsApi().getCollections(
pageSize = 20,
orderBy = "name",
direction = "asc"
)
View the OpenAPI spec for a full list of API requests available in the Core SDK.
Utility functions that will chain necessary API calls to complete a process or perform a transaction.
- Register a user with ImmutableX and returns the Stark key pair
- Buy cryptocurrency via Moonpay
- Buy ERC721
- Sell ERC721
- Cancel listing
- Transfer ERC20/ERC721/ETH
In order to use any workflow functions, you will need to pass in the connected wallet provider. This means you will need to implement your own Wallet L1 Signer and L2 StarkSigner.
Once you have a Signer
instance you can generate the user's Stark key pair and use the result to implement a StarkSigner
.
StarkKey.generate(signer).whenComplete { keyPair, error ->
StarkKey.sign(keyPair, "0x5369676e2074686973")
}
Parts of the Core SDK are automagically generated.
We use OpenAPI (formally known as Swagger) to auto-generate the API clients that connect to the public APIs.
The OpenAPI spec is retrieved from https://api.x.immutable.com/openapi and also saved in the repo here.
When updating the org.openapi.generator
plugin ensure that any custom templates are appropriately modified or removed. These can be found in the .openapi-generator/templates directory.
The generation always happens on preBuild so triggering a project build will regenerate them.
Rx provides a fromFuture
method that will trigger future.get()
which is a blocking call so it must be moved off the main thread.
Disposing the resulting observable will not cancel the future so that needs to be done manually using doOnDispose
.
val future = ImmutableWallet.cancel(orderId)
Observable.fromFuture(future)
.subscribeOn(Schedulers.io())
.doOnDispose { future.cancel(true) }
.subscribe({ handleSuccess() }, { handleError() })
The Kotlin team has a set of packages for jdk8 that provide an easy extension for using CompletableFuture.
First add this import to your project:
implementation "org.jetbrains.kotlinx:kotlinx-coroutines-jdk8:$coroutines_version"
Then simply call .await()
on the workflow CompletableFuture
and wrap it with a try/catch to handle any exceptions.
launch(Dispatchers.Default) {
try {
val id = ImmutableWallet.cancel(orderId).await()
} catch (e: Exception) {
handleError(e)
}
}
The following headings should be used as appropriate
- Added
- Changed
- Deprecated
- Removed
- Fixed
What follows is an example with all the change headings, for real world use only use headings when appropriate. This goes at the top of the CHANGELOG.md above the most recent release.
...
## [Unreleased]
### Added
for new features.
### Changed
for changes in existing functionality.
### Deprecated
for soon-to-be removed features.
### Removed
for now removed features.
### Fixed
for any bug fixes.
...
The version.yml will hold the value of the previous release
version: 0.1.0
If you would like to contribute, please read the following:
- We use the Conventional Commits specification when writing our commit messages. Why use Conventional Commits? Read here.
Immutable X is open to all to build on, with no approvals required. If you want to talk to us to learn more, or apply for developer grants, click below:
To get help from other developers, discuss ideas, and stay up-to-date on what's happening, become a part of our community on Discord.
You can also join the conversation, connect with other projects, and ask questions in our Immutable X Discourse forum.
You can also apply for marketing support for your project. Or, if you need help with an issue related to what you're building with Immutable X, click below to submit an issue. Select I have a question or issue related to building on Immutable X as your issue type.
ImmutableX Core SDK Kotlin/JVM repository is distributed under the terms of the Apache License (Version 2.0).