Skip to content
/ sdk Public
forked from fakhrisati/solussdk

Official noebs java sdk. Access all noebs services via a simple, easy to use api.

Notifications You must be signed in to change notification settings

noebs/sdk

Repository files navigation

Noebs Java Client

Add it in your root build.gradle

repositories {
  		...
  		maven { url 'https://jitpack.io' }
  	}

Add the dependency

dependencies {
          implementation 'com.github.tutipay:java-sdk:-SNAPSHOT' # add this stage always use the bleeding edge version
 }

How does the api work

We are trying to simplify the API as much as we can, while the API is currently rapidly changing we are using it in production capacities.

How to use noebs sdk

  1. Create an instance of the client

val tutiApiClient = TutiApiClient()

  1. Depending on which services you are using, some services need to be authenticated first, we do that this way: tutiApiClient.authToken = token

  2. You are good to go now, let's start by a simple request that is getting (no)ebs public key: But before that most of function signatures are this way, only varies a few parameters

public void getPublicKey(EBSRequest ebsRequest, TutiApiClient.ResponseCallable<TutiResponse> onResponse, TutiApiClient.ErrorCallable<TutiResponse> onError)

Now, let's try to use that API:

client.getPublicKey(com.tuti.api.ebs.EBSRequest(), { response, _ ->
            run {
                if (response != null) {
                    Log.i("Public key response", response.ebsResponse.pubKeyValue)
                }
            }
        }, { error, exception, rawResponse ->
        run {
            // You can log exceptions here
            Log.i("NOEBS", exception.stackTrace)
        }  
        })

NOTES

Some logic needs to run within the main thread, e.g., if you want to show a toast, or navigate to a new fragment, for that we simply update the code as following:

client.getPublicKey(com.tuti.api.ebs.EBSRequest(), { response, _ ->
            run {
                if (response != null) {
                    Log.i("Public key response", response.ebsResponse.pubKeyValue)
                }
            }
        }, { error, exception, rawResponse ->
        run {
            Handler(Looper.getMainLooper()).post {
              Toast.makeText(
                        applicationContext,
                        "Key downloading failed. Code: " + error?.code,
                        Toast.LENGTH_SHORT
                    ).show()
            }
            Log.i("NOEBS", exception.stackTrace)
        }  
        })

Note how the log is running outside the main looper, while the toast runs within the main thread's.

Deployment notes

We will still be sticking to jitpack, at least for the public builds. However, we are using github package (using gradle repository).

noebs sdk versioning

We are using CalVer, it is very convenient as it shows actual progress against time. Seems more concrete than say semver. Jitpack relies on git tags, so the easiest way is to always tag your commits following CalVer semantics (vYY.MM.versionNumber)

how to deploy noebs to Github Packages

  • Update the version number manually in gradle.properties version to reflect the new CalVer changes
  • In lib/build.gradle, update the username and password with the appropriate Github issues keys (note the password is a a personal access token, and not your password)
repositories {
        maven {
            name = "GitHubPackages"
            url = uri("https://maven.pkg.github.com/tutipay/java-sdk")
            credentials {
                username = project.findProperty("gpr.user") ?: System.getenv("USERNAME")
                password = project.findProperty("gpr.key") ?: System.getenv("TOKEN")
            }
        }
    }
  • That is it actually!

how to use noebs published Github Package

  • Update your build.gradle files to include github package
        maven {
            url = uri("https://maven.pkg.github.com/tutipay/java-sdk")
            credentials {
                username = project.findProperty("gpr.user") ?: System.getenv("USERNAME")
                password = project.findProperty("gpr.key") ?: System.getenv("TOKEN")
            }
        }
  • add to your app's gradle file the implementation, which is implementation 'noebs:lib:22.10.27'

About

Official noebs java sdk. Access all noebs services via a simple, easy to use api.

Topics

Resources

Stars

Watchers

Forks

Languages

  • Kotlin 80.8%
  • Java 19.2%