Skip to content

Latest commit

 

History

History
104 lines (75 loc) · 3.26 KB

README.md

File metadata and controls

104 lines (75 loc) · 3.26 KB

EthereumKit

EthereumKit is a Swift framework that enables you to create Ethereum wallet and use it in your app.

🚨 EthereumKit is currently under development. not ready for the production use 🚨

Features

  • Mnemonic recovery phrease in BIP39
  • BIP32/BIP44 HD wallet
  • EIP55 format address encoding
  • See currency balance of an address.

How to Use

Wallet

  • BIP39: Generate seed and mnemonic sentence.
let entropy = Data(hex: "000102030405060708090a0b0c0d0e0f")
let mnemonic = Mnemonic.create(entropy: entropy)
print(mnemonic)
// abandon amount liar amount expire adjust cage candy arch gather drum buyer

let seed = Mnemonic.createSeed(mnemonic: mnemonic)
print(seed.toHexString())
  • BIP32: PrivateKey and key derivation.
// m/44'/60'/0'/0
let masterPrivateKey = PrivateKey(seed: seed, network: .main)
let purpose = masterPrivateKey.derived(at: 44, hardens: true)
let coinType = purpose.derived(at: 60, hardens: true)
let account = coinType.derived(at: 0, hardens: true)
let change = account.derived(at: 0)

// m/44'/60'/0'/0/0
let privateKey = change.derived(at: 0)
  • Create your wallet and generate addresse.
// It generates master key pair from the seed provided.
let wallet = Wallet(seed: seed, network: .main)

let firstAddress = wallet.receiveAddress(at: 0)
// 0x83f1caAdaBeEC2945b73087F803d404F054Cc2B7

let secondAddress = wallet.receiveAddress(at: 1)
// 0xb3c3D923CFc4d551b38Db8A86BbA42B623D063cE

let thirdAddress = wallet.receiveAddress(at: 2)
// 0x82e35B34CfBEB9704E51Eb17f8263d919786E66a

Geth

Communicate with Ethereum blockchain via Geth.

Geth interacts with Ethereum via JSONRPC. It connects to Ropsten for test network and Mainnet for main network. (Will support localhost⚠️)

Supporting APIs

  • GetBalance (Get a balance of a specific address)
    • Parameters
      • address: The Address you want to get a balance of.
      • blockParameter: The default is latest. You can set latest, earliest, pending.
let geth = Geth(network: .test)
geth.getAccount(address: "0x91c79f31De5208fadCbF83f0a7B0A9b6d8aBA90F") { result in
    // do something with `Balance`.
}
  • GetAccount (Get a balance of a specific address and convert it to Account model.)
    • Parameters
      • address: The Address you want to get a balance of.
      • blockParameter: The default is latest. You can set latest, earliest, pending.
let geth = Geth(network: .test)
geth.getAccount(address: "0x91c79f31De5208fadCbF83f0a7B0A9b6d8aBA90F") { result in
    // do something with `Account`.
}

Installation

  • Insert github "yuzushioh/EthereumKit" to your Cartfile.
  • Run carthage update --platform ios.

Made possible by

License

EthereumKit is released under the MIT License.