Lisk Elements
Lisk Elements is a JavaScript library for Lisk, the blockchain application platform.
Installation
Installation via npm
Add Lisk Elements as a dependency of your project:
$ npm install --save lisk-elements
Import using ES6 modules syntax:
import lisk from 'lisk-elements';
Or using Node.js modules:
const lisk = require('lisk-elements');
Or import specific namespaced functionality:
import { APIClient, transactions } from 'lisk-elements';
const { APIClient, transactions } = require('lisk-elements');
Note: If you are installing Lisk Elements as an npm dependency via a GitHub reference, you will need to manually build the distribution files by running the following commands from the root directory of your project:
cd node_modules/lisk-elements
npm run build
Installation from source
Our source code is hosted on GitHub. You can build the distribution yourself by cloning the repository, installing the relevant dependencies and running our build script as follows:
git clone https://github.com/LiskHQ/lisk-elements.git
cd lisk-elements/packages/lisk-elements
npm install
npm run build
Usage
Access functionality via the relevant namespace. For example, the following will create and (locally) sign a transfer (type 0) transaction, and then broadcast it to the Lisk Testnet.
const transaction = lisk.transaction.transfer({
amount: '123000000',
recipientId: '12668885769632475474L',
passphrase:
'robust swift grocery peasant forget share enable convince deputy road keep cheap',
});
const client = lisk.APIClient.createTestnetAPIClient();
client.transactions
.broadcast(transaction)
.then(console.info)
.catch(console.error);
Full documentation can be found on the Lisk documentation site.
Packages
Tests
To run tests for all packages in lisk-elements, run the following command in the root folder:
npm test
To run tests for a specific package, run the same command in the relevant package directory.
Example:
cd packages/lisk-cryptography
npm test
FAQ
Installation is failing, what should I do?
Make sure you are installing in the root folder, not on the package level.
Run `npm run clean` and `npm run clean:node_modules`, then install again.
I can't build the package, what should I do?
Make sure you first run `npm i`, and then `npm run build` in the root directory.
Tests are failing!
Make sure you are using the correct version of node and npm.
In our current build we recommend node v8.12.0 and npm v6.4.1.
Contributors
https://github.com/LiskHQ/lisk-elements/graphs/contributors
License
Copyright 2016-2019 Lisk Foundation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Copyright © 2016-2019 Lisk Foundation
Copyright © 2015 Crypti
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.