2a73753e36 | ||
---|---|---|
Examples/MnemonicSwiftExample.playground | ||
MnemonicSwift | ||
MnemonicSwift.xcodeproj | ||
Tests | ||
.gitignore | ||
.slather.yml | ||
.swiftlint.yml | ||
.travis.yml | ||
CHANGELOG.md | ||
COPYING.md | ||
Cartfile | ||
Cartfile.resolved | ||
Gemfile | ||
LICENSE-APACHE | ||
LICENSE-MIT | ||
MnemonicSwift.podspec | ||
NOTICE.SwiftCrypto.txt | ||
Package.resolved | ||
Package.swift | ||
README.md | ||
codecov.yml | ||
project.yml |
README.md
MnemonicSwift
An implementation of BIP39 in Swift. MnemonicSwift supports both English and Chinese mnemonics.
This library is a fork of MnemonicKit. This fork provides provides support for BIP39 using Crypto.
NOTE to 1.0.0 users: If you are using 1.0.0 in your project, we no longer maintain that version. Upgrade to 2.0.0 immediately.
Installation
CocoaPods
MnemonicSwift supports installation via CocoaPods. You can depened on MnemonicSwift by adding the following to your Podfile:
pod "MnemonicSwift"
Carthage
If you use Carthage to manage your dependencies, simply add
MnemonicSwift to your Cartfile
:
github "zcash-hackworks/MnemonicSwift"
Usage
Generate a Mnemonic
let englishMnemonic = Mnemonic.generateMnemonic(strength: 64, language: .english)
let chineseMnemonic = Mnemonic.generateMnemonic(strength: 128, language: .chinese)
Generate a Mnemonic from a Hex Representation
let hexRepresentation: String = ...
let mnemonic = Mnemonic.mnemonicString(from: hexRepresentation)
print("Mnemonic: \(mnemonic)\nFrom hex string: \(hexRepresentation)")
Generate a Seed String
let englishMnemonic = Mnemonic.generateMnemonic(strength: 64, language: .english)
let passphrase: String = ...
let deterministicSeedString = Mnemonic.deterministicSeedString(from: mnemonicString,
passphrase: passphrase,
language: .english)
print("Deterministic Seed String: \(deterministicSeedString)")
Setting up the project as contributor
To get set up:
$ brew install xcodegen # if you don't already have it
$ xcodegen generate # Generate an XCode project from Project.yml
$ open MnemonicSwift.xcodeproj
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.