A Retrofit-like Ethereum client for Android, Java, and Kotlin.
Etherspace is a type-safe Ethereum client to interact with Ethereum Smart Contract.
For example, to access greeter
smart contract from ETHEREUM » Create a digital greeter (Slightly modified because we need a setter):
contract greeter {
/* Define variable greeting of the type string */
string greeting;
/* This runs when the contract is executed */
function greeter(string _greeting) public {
greeting = _greeting;
}
/* Main function */
function greet() constant returns (string) {
return greeting;
}
/* Update greeting */
function newGreeting(string _greeting) public returns (string) {
greeting = _greeting;
return greeting;
}
}
By defining a Smart Contract interface in Kotlin / Java: (see: Smart Contract Interface)
// Kotlin
interface Greeter {
@Throws(IOException::class)
@Send
fun newGreeting(greeting: String): TransactionHash
@Throws(IOException::class)
@Call
fun greet(): String
}
// Java
public interface Greeter {
@Send
TransactionHash newGreeting(String greeting) throws IOException;
@Call
String greet() throws IOException;
}
Etherspace generates an implementation of Greeter
interface.
You can than use greeter
to interact with Smart Contract on Ethereum!
// Kotlin
val etherSpace = EtherSpace.build {
provider = "https://rinkeby.infura.io/" // Or your local node
credentials = Credentials(YOUR_PRIVATE_KEY_OR_WALLET)
}
var greeter = etherSpace.create(SMART_CONTRACT_ADDRESS, Greeter::class.java)
val hash = greeter.newGreeting("Hello World")
val receipt = hash.requestTransactionReceipt<TransactionReceipt>()
println(greeter.greet()) // Should be "Hello World"
// Java
EtherSpace etherSpace = new EtherSpace.Builder()
.provider("https://rinkeby.infura.io/") // Or your local node
.credentials(new Credentials(YOUR_PRIVATE_KEY_OR_WALLET))
.build();
Greeter greeter = etherSpace.create(SMART_CONTRACT_ADDRESS, Greeter.class);
TransactionHash hash = greeter.newGreeting("Hello World");
TransactionReceipt receipt = hash.requestTransactionReceipt();
System.out.println(greeter.greet()); // Should be "Hello World"
- Java / Kotlin: etherspace-java-example
- Android: etherspace-android-example
-
Gradle
repositories { ... maven { url 'https://jitpack.io' } // should be the last entry } dependencies { ... // JDK 8 compile 'cc.etherspace.etherspace-java:etherspace-java:{version}' // Android implementation 'cc.etherspace.etherspace-java:etherspace-android:{version}' }
-
Maven
<repositories> <repository> <id>jitpack.io</id> <url>https://jitpack.io</url> </repository> </repositories> <!-- JDK 8 --> <dependency> <groupId>cc.etherspace.etherspace-java</groupId> <artifactId>etherspace-java</artifactId> <version>{version}</version> </dependency> <!-- Android --> <dependency> <groupId>cc.etherspace.etherspace-java</groupId> <artifactId>etherspace-android</artifactId> <version>{version}</version> </dependency>
Please submit issues or pull requests for bugs and features, or contact me at tempo@zaoo.com. Any feedback is welcome!
- Etherspace is built with Kotlin.
- Built on top of web3j.
- Inspired by Retrofit.
- Included libraries:
- web3j: https://github.com/web3j/web3j
- kotlin-unsigned: https://github.com/kotlin-graphics/kotlin-unsigned
- jackson: https://github.com/FasterXML/jackson
- guava: https://github.com/google/guava