Core logic to develop an Ethereum Lumerin wallet.
The core logic has a modular design where each module or plugin can emit events and expose methods to other plugins or the code client.
Minimum Node version required is v12, v14 is recommended
const createCore = require('lumerin-wallet-core');
const core = createCore();
const { api, emitter, events } = core.start();
// Listen for `events` on the `emitter`.
// Call `api` methods
core.stop();
-
createCore()
: Creates a wallet core instance. -
core.start({ config })
: Initializes the core logic. Returns an object containing the exposed methods inapi
, anemitter
to expose events and the list of emitted events in theevents
array. See below for details. -
core.stop()
: stops everything.
The configuration object has default properties as defined in src/defaultConfig.json
.
All plugins must follow this pattern:
function createPlugin () {
return {
start ({ config, eventBus, plugins }) {
// Initialize
return { events, name, api }
},
stop () {
// Clean up
}
}
}
The start
method will receive the core config
, an eventBus
emitter and an object containing all the other plugin's exposed methods.
The return object shall contain a list of events
that might be interesting to the core's user, the name
of the plugin and an object containing all api
methods exposed.
The eventBus
is the same instance as core.start().emitter
.
All methods exposed by all plugins will be available to all other plugins and namespaced core.start().api
using the name
property.
The following plugins are bundled:
eth
: Provides connectivity with the Ethereum node.explorer
: Provides notifications and keeps track of new blocks, transactions and events.lumerin
: Provides Lumerin-specific functionality as interacting with the auctions, converter and token contracts.rates
: Provides crypto-to-fiat exchange rates.tokens
: Provides base ERC20 token functions.wallet
: Provides base key/account management
TODO - Remove Deployment instructions after ci/cd setup
git tag {new_version}
npm login --scope=@lumerin
| | | | |
v v v v v
npm publish --access=public
Publish Order: @lumerin/contracts @lumerin/wallet-ui-logic @lumerin/wallet-core
MIT