Skip to content

Lumerin-protocol/WalletCore

Repository files navigation

Lumerin Wallet Core Library

# lumerin-wallet-core

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.

Quick start

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();

API

  • createCore(): Creates a wallet core instance.

  • core.start({ config }): Initializes the core logic. Returns an object containing the exposed methods in api, an emitter to expose events and the list of emitted events in the events array. See below for details.

  • core.stop(): stops everything.

Config

The configuration object has default properties as defined in src/defaultConfig.json.

Plugins (modules)

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

INTERNAL DEPLOYMENT ONLY

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

License

MIT

About

Core logic to develop an Ethereum Lumerin wallet

Resources

License

Stars

Watchers

Forks

Packages

No packages published