Skip to content
This repository has been archived by the owner on Feb 15, 2018. It is now read-only.

Android library responsible for creating a new Ethereum account and managing KIN balance and transactions.

License

Notifications You must be signed in to change notification settings

kinecosystem/kin-core-android-ethereum

Repository files navigation

Kin core SDK for Android

Android library responsible for creating a new Ethereum account and managing KIN balance and transactions. Kin Token

End-of-Life

This SDK is no longer supported for new users. Please see kin-core-android for the current SDK.

Build

  • Add this to your module's build.gradle file.
repositories {
    ...
    maven {
        url "https://dl.bintray.com/kinfoundation/go-ethereum"
    }
    maven {
        url 'https://jitpack.io'
    }
}
...
dependencies {
    ...
    compile "kinfoundation.ethereum:geth:1.0.2@aar"
    compile "com.github.kinfoundation:kin-sdk-core-android:LATEST-COMMIT-ON-DEV-BRANCH"
}

In the above build.gradle:

  • LATEST-COMMIT-ON-DEV-BRANCH stands for the first 10 characters of our latest commit on dev branch. For example: d9bb37a7e2

Usage

Connecting to a service provider

To start using our SDK, create a new KinClient with two arguments: an android Context and a ServiceProvider.

A ServiceProvider is a service that provides access to the Ethereum network. The example below creates a ServiceProvider that will be used to connect to the main (production) Ethereum network, via Infura. To obtain an Infura token you can register here

ServiceProvider infuraProvider =  
    new ServiceProvider("https://main.infura.io/INFURA_TOKEN", ServiceProvider.NETWORK_ID_MAIN));
KinClient kinClient = new KinClient(context, infuraProvider);

To connect to a test ethereum network use the following ServiceProvider:

new ServiceProvider("https://ropsten.infura.io/INFURA_TOKEN", ServiceProvider.NETWORK_ID_ROPSTEN)

Unfortunately there is no guarantee that getPendingBalance will work when working with an Infura provider because of an existing known issue with the geth implementation of the ethereum protocol.
In order for getPendingBalance to work as expected you will need to connect to a node running a parity implementation of the protocol. Let us know if you need help with that.

Creating and retrieving a KIN account

The first time you use KinClient you need to create a new account, using a passphrase. The details of the account created will be securely stored on the device.

KinAccount account;
try {
    if (!kinClient.hasAccount()) {
        account = kinClient.createAccount("yourPassphrase");
    }
} catch (CreateAccountException e) {
    e.printStackTrace();
}

Once an account has been created there is no need to call createAccount again on the same device. From then on calling getAccount will retrieve the account stored on the device.

if (kinClient.hasAccount()) {
    account = kinClient.getAccount();
}

You can delete your account from the device using deleteAccount with the passphrase you used to create it as a parameter, but beware! Unless you export it first using exportKeyStore you will lose all your existing KIN if you do this.

kinClient.deleteAccount(String passphrase);

Public Address and JSON keystore

Your account can be identified via it's public address. To retrieve the account public address use:

account.getPublicAddress();

You can export the account keystore file as JSON using the exportKeyStore method

 try {
    String oldPassphrase = "yourPassphrase";
    String newPassphrase = "newPassphrase";
    String json = account.exportKeyStore(oldPassphrase, newPassphrase);
    Log.d("example", "The keystore JSON: " + json);
 }
 catch (PassphraseException e){
    e.printStackTrace();
 }

Retrieving Balance

To retrieve the balance of your account in KIN call the getBalance method:

Request<Balance> balanceRequest = account.getBalance();
balanceRequest.run(new ResultCallback<Balance>() {

    @Override
    public void onResult(Balance result) {
        Log.d("example", "The balance is: " + result.value(2));
    }

    @Override
        public void onError(Exception e) {
            e.printStackTrace();
        }
});

Transfering KIN to another account

To transfer KIN to another account, you need the public address of the account you want to transfer the KIN to.

The following code will transfer 20 KIN to account "#AB12349ACF123".

String toAddress = "#AB12349ACF123";
String passphrase = "yourPassphrase";
BigDecimal amountInKin = new BigDecimal("20");


transactionRequest = account.sendTransaction(toAddress, getPassphrase(), amount);
transactionRequest.run(new ResultCallback<TransactionId>() {

    @Override
        public void onResult(TransactionId result) {
            Log.d("example", "The transaction id: " + result.toString());
        }

        @Override
        public void onError(Exception e) {
            e.printStackTrace();
        }
});

Retrieving Pending Balance

**This may not work with an infura ServiceProvider, as discussed here **

It takes some time for transactions to be confirmed. In the meantime you can call getPendingBalance to get the amount of KIN that you will have once all your pending transactions are confirmed.

For example, if you have 40KIN and then transfer 5KIN to your friend, until the transaction of the 5KIN gets to be confirmed getBalance will return 40KIN and getPendingBalance will return 35KIN.

Similarly if you have 30KIN and someone else transfer 2KIN to you, until the transaction gets to be confirmed getBalance will return 30KIN and getPendingBalance will return 32KIN.

Request<Balance> balanceRequest = account.getPendingBalance();
balanceRequest.run(new ResultCallback<Balance>() {

    @Override
        public void onResult(Balance result) {
            Log.d("example", "The balance is: " + result.toString());
        }

        @Override
        public void onError(Exception e) {
            e.printStackTrace();
        }
});

Sync vs Async

Asynchronous requests are supported by our Request object. The request.run() method will perform the request on a serial background thread and notify success/failure using ResultCallback on the android main thread. In addition, cancel(boolean) method can be used to safely cancel requests and detach callbacks.

A synchronous version of these methods is also provided. Make sure you call them in a background thread.

try {
    account.getBalanceSync();
}
catch (OperationFailedException e) {
   // something went wrong - check the exception message
}

try {
    account.getPendingBalanceSync();
}
catch (OperationFailedException e){
   // something went wrong - check the exception message
}

try {
    account.sendTransactionSync(toAddress, passphrase, amountInKin);
}
catch (PassphraseException e){
    // there passphrase used was wrong
}
catch (OperationFailedException e){
    // something else went wrong - check the exception message
} 

Sample Application

For a more detailed example on how to use the library please take a look at our Sample App.

Testing

We use ethereumjs/testrpc and Truffle framework unit tests.

When running the SDK test target, pre-action and post-action tasks in build.gradle (Module: kin-sdk-core) will setup truffle and testrpc to run for the duration of the test.

Requirements

Node.js and npm. You can install these using homebrew:

$ brew install node

Next, install specific npm packages using:

$ cd kin-sdk-core/truffle
$ npm install

Next, initialize and update git submodules. This will include kin-sdk-core/truffle/kin-token.

$ git submodule init && git submodule update

How to run the tests

  • From command line
    Run the below command from the root directory.
    It will run all the tests and also clean testrpc at the end.
$ make test
  • From Android Studio
    Our test classes are here. You can run the tests directly from Android Studio but will still have to run clean testrpc manually.

Clean testrpc manually

Run the below command from the root directory.

$ make clean

Contributing

Please review our CONTRIBUTING.md guide before opening issues and pull requests.

License

The kin-sdk-core-android library is licensed under MIT license.

About

Android library responsible for creating a new Ethereum account and managing KIN balance and transactions.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published