Skip to content

sprngbk/imx-core-sdk-kotlin-jvm

 
 

Repository files navigation


ImmutableX Core SDK Kotlin/JVM

The Immutable Core SDK Kotlin/JVM provides convenient access to the Immutable API's for applications written on the Immutable X platform.

Documentation

See the developer guides for information on building on Immutable X.

See the API reference documentation for more information on our API's.

Installation

  1. Create an Access Token (see here) with read:packages enabled.
  2. Add the GitHub package as a repository either in your build.gradle file or settings.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'
}
  1. Set the correct environment (Ropsten or Production/Mainnet)
ImmutableXCore.setBase(ImmutableXBase.Ropsten)

Usage

Standard API Requests

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.

Workflow Functions

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

Wallet Connection

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")
}

Autogenerated Code

Parts of the Core SDK are automagically generated.

API Autogenerated Code

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.

Wrapping CompletableFuture

RxJava

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() })

Coroutines

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)
    }
}

Changelog Management

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

Contributing

If you would like to contribute, please read the following:

Maintainers

Getting Help

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:

Contact us

Project Support

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.

Join us on Discord

You can also join the conversation, connect with other projects, and ask questions in our Immutable X Discourse forum.

Visit the forum

Still need help?

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.

Contact support

License

ImmutableX Core SDK Kotlin/JVM repository is distributed under the terms of the Apache License (Version 2.0).

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Kotlin 94.3%
  • Mustache 5.7%